В Си функция может раскрыть память, которой она «управляет» на более низком уровне, как только для чтения тем, кто вызывает эту функцию (выставляя свой адрес). return * const
неэффективно, но мне было интересно, пропустил ли я тик программирования?
Спасибо.
const uint8_t * get_value(int index)
{
static uint8_t data[2] = {0, 0};
return (const uint8_t *)&data[index];
}
int main(void)
{
uint8_t * value;
value = get_value(1);
*value += 1;
return 0;
}
@ j_random_hacker Предложил хороший компромисс на мой вопрос, который создает дополнительный барьер, который я ищу, для предотвращения случайного неправильного использования этих данных.
typedef struct
{
const uint8_t * value;
const uint8_t size;
} readonly_t;
readonly_t get_value(int index, int size)
{
static uint8_t data[2] = {0, 0};
uint8_t rsize;
/* ... validate index, size params */
readonly_t r = { &data[index], rsize };
return r;
}