Descripción general de la configuración

El AOSP ofrece las siguientes opciones para almacenar información de configuración en un dispositivo:

  • Propiedades del sistema
  • Propiedades de la capa de abstracción de hardware (HAL)
  • Archivos XML de configuración del sistema
  • Superposiciones de recursos (estáticas y en tiempo de ejecución)

Propiedades del sistema

Las propiedades del sistema son pares clave-valor de cadena almacenados en el diccionario global de build.prop. Las propiedades del sistema son recursos de todo el sistema que son fáciles de usar y tienen una sobrecarga de rendimiento baja. Cuando usas propiedades del sistema, no necesitas usar la comunicación entre procesos (IPC) incluso si una propiedad del sistema se comparte entre varios procesos. Sin embargo, las propiedades del sistema son similares a las variables globales y pueden ser perjudiciales si se usan de forma inadecuada. El uso inadecuado de las propiedades del sistema puede provocar problemas como vulnerabilidades de seguridad y que los usuarios no puedan acceder a las apps. Antes de usar las propiedades del sistema para almacenar información de configuración, considera las otras opciones de configuración.

Para obtener más información sobre las propiedades del sistema, consulta Cómo agregar propiedades del sistema.

Propiedades del HAL

Cuando la fuente de información de una configuración proviene de un componente de hardware en un dispositivo, el HAL del hardware debe proporcionar la información de ese componente. Define un nuevo método de HAL en la HAL existente para acceder a la configuración. Para obtener más información sobre cómo desarrollar un HAL, consulta AIDL para HALs.

Archivos XML de configuración del sistema

Cuando los datos de configuración son estáticos pero complejos (estructurados), considera usar XML o algún otro formato similar para los datos de configuración. Asegúrate de que el esquema del archivo permanezca estable. En el caso de los archivos XML, puedes usar xsd_config para mantener el esquema estable y aprovechar un analizador de XML generado automáticamente.

Superposición de recursos

Puedes usar superposiciones de recursos para personalizar un producto. Existen dos tipos de superposiciones de recursos:

  • Superposición de recursos estándar que se usa para personalizar un producto en el tiempo de compilación. Para obtener información sobre las superposiciones de recursos estándar, consulta Cómo personalizar la compilación con superposiciones de recursos.

  • La superposición de recursos del entorno de ejecución (RRO) se usa para cambiar los valores de los recursos de un paquete objetivo en el entorno de ejecución. Por ejemplo, una app instalada en la imagen del sistema podría cambiar su comportamiento según el valor de un recurso. En lugar de codificar de forma rígida el valor del recurso en el momento de la compilación, un RRO instalado en una partición diferente puede cambiar los valores de los recursos de la app en el tiempo de ejecución. Para obtener más información sobre las RRO, consulta Cómo cambiar el valor de los recursos de una app en el tiempo de ejecución.