【问题标题】:Fear of Overwriting Referenced Data in Struct害怕覆盖结构中的引用数据
【发布时间】:2021-09-08 23:00:35
【问题描述】:

我有一个关于数据缓冲区指针的问题,我不知道如何在 Google 上搜索这个问题,因为我不知道它可能被称为什么。所以...

我有一个函数,它采用结构 PCA9745 并使用函数输入配置它的一些参数,如下所示。我关心的是数组指针......当函数 _PCA9745_Configure() 完成时,在函数返回后是否释放数组(到缓冲区),从而使数组指针变得无用,因为它可能会得到重写了吗?

我想要一种方法来创建数组引用,一旦函数返回就不会过时,而无需在 ma​​in.c 中声明数组以隐藏一些丑陋并使其更加用户友好。

PCA9745_io.c

void _PCA9745_Configure(PCA9745 *p, float r_ext, uint16_t num_dev){
    p->r_ext = r_ext;
    p->num_dev = num_dev;
    uint8_t instr_buffer[num_dev];
    uint8_t data_buffer[num_dev];
    uint8_t rx_buffer[num_dev];
    p->instr_buffer = &instr_buffer;
    p->data_buffer = &data_buffer;
    p->rx_buffer = &rx_buffer;
}

PCA9745 结构

typedef struct {
    SPI_HandleTypeDef *hspi;
    GPIO_TypeDef *gpio_port_nCS;
    uint16_t gpio_pin_nCS;
    GPIO_TypeDef *gpio_port_nOE;
    uint16_t gpio_pin_nOE;

    //Must include for PCA9745.c to compile
    float r_ext;            //External Resistor value
    uint16_t num_dev;       //number of devices
    uint8_t *instr_buffer[];
    uint8_t *data_buffer[];
    uint8_t *rx_buffer[];
} PCA9745;

ma​​in.c

PCA9745 p = Init_PCA9745(&hspi1, nCS_GPIO_Port, nCS_Pin, nOE_GPIO_Port, nOE_Pin);
_PCA9745_Configure(&p, 3600.0f, 1);

【问题讨论】:

  • 是的,它们被释放是因为它们是本地的。您的平台是否支持动态分配(malloc() 等)?
  • _PCA9745_Configure() 函数不正确,因为它的指针成员包含局部变量的地址,当您从函数返回时,这些局部变量将终止生命。您也有不匹配的间接,因为(我认为,那些只是代码片段)成员 uint8_t *instr_buffer[]; 应该是 uint8_t *instr_buffer; 如果您不希望引用过时,请在您之前使用 mallocfree 它们freestruct.
  • 您的 PCA9745 不是有效的 C,因为它最后有三个灵活的数组成员。只有最后一个成员被允许成为灵活的数组成员(并且仅当它不是结构的唯一成员时)。
  • @IanAbbott IMO 它们不应该是指针数组,而是 uint8_t *instr_buffer 等评论。间接级别不匹配。
  • @WeatherVane TBH,很难在代码中找到任何没有错误的东西!

标签: c pointers stm32 garbage


【解决方案1】:

我个人会选择这样的东西,但如果你想变得花哨,你可以从 init 返回一个结构。

#include <stdio.h>
#include <string.h>
#include <stdint.h>

#define PCA9745_BUF_SIZE 512

typedef struct {
    //SPI_HandleTypeDef *hspi; // I dont have these types :)
    //GPIO_TypeDef *gpio_port_nCS;
    //GPIO_TypeDef *gpio_port_nOE;
    uint16_t gpio_pin_nOE;
    uint16_t gpio_pin_nCS; 
    uint16_t num_dev;       //number of devices
    float r_ext;            //External Resistor value 
    uint8_t *instr_buffer;
    uint8_t *data_buffer;
    uint8_t *rx_buffer;
} PCA9745_t;

static uint8_t instr_buf[PCA9745_BUF_SIZE];
static uint8_t data_buf[PCA9745_BUF_SIZE];
static uint8_t rx_buf[PCA9745_BUF_SIZE];

void _PCA9745_init(PCA9745_t *p);

int main(void)
{

    PCA9745_t PCA9745 = 
    {
        //.hspi = &spi1,
        //.gpio_port_nCS = my_favorite_gpio,
        //...,
        .instr_buffer = instr_buf,
        .data_buffer = data_buf,
        .rx_buffer = rx_buf
    };
    
    _PCA9745_init(&PCA9745);
    
    // Just for test :)
    for(int i = 0; i < PCA9745_BUF_SIZE; i++){
    printf("%d",*(PCA9745.rx_buffer+i));
    }
    
  return 0;
}


void _PCA9745_init(PCA9745_t *p){
    memset(p->instr_buffer,0,PCA9745_BUF_SIZE);
    memset(p->data_buffer,0,PCA9745_BUF_SIZE);
    memset(p->rx_buffer,9,PCA9745_BUF_SIZE); // fill it with something known
    //.....
    p->r_ext = 1;
    p->num_dev = 1;
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2023-03-15
    • 1970-01-01
    • 1970-01-01
    • 2016-01-21
    • 2017-08-11
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多