一个指针加结构体的问题导致芯片不能运行
简化描述:我在程序中定义了如下类型的一个结构体:
typedef struct
{
uint8_t* Rxbuffer;
uint8_t Timer;
}Hardle_typedef;
然后用Hardle_typedef去定义一个变量,结果芯片没现象,改成如下形式就没问题了:
typedef struct
{
uint8_t Timer;
uint8_t* Rxbuffer;
}Hardle_typedef;
请问大神们这是踩了C语言指针的陷阱了吗?请帮忙解释一下。
定义后,Rxbuffer是否进行了赋值? 结构体是一种自定义的数据类型,是创建变量的模板,不占用内存空间;结构体变量才包含了实实在在的数据,需要内存空间来存储。 所以我觉得你定义的没有问题 ,看看你的变量是怎么样的啊 bargagebaobei 发表于 2018-3-30 11:40
结构体是一种自定义的数据类型,是创建变量的模板,不占用内存空间;结构体变量才包含了实实在在的数据,需 ...
比如定义Hardle_typedef PE_Handle,然后程序中用了PE_Handle,经过编译发现上述两种结构体的情况占用的SRAM居然是不一样的 一般的内存分配都是连续性的分配块内存的,指针变量存的是将要跳转的空间地址,没有把开辟的地址赋给嵌套在内层的指针变量!这样跳转到的地址并不一定就在刚分配开辟的连续地址内,只有将开辟的内存地址写在指针变量里,才能让指针跳到指定的开辟的内存空间!
本帖最后由 XinLiYF 于 2018-3-30 12:39 编辑
jxbjxbjxb 发表于 2018-3-30 11:46
比如定义Hardle_typedef PE_Handle,然后程序中用了PE_Handle,经过编译发现上述两种结构体的情况占用的S ...
默认情况下,都是四字节对齐的。指针是地址,占四个字节,uint8_t占一个字节。如果把uint8_t放到结构体的开头(第二个结构体)结构体占八个字节。如果放到结构体尾部(第一个结构体)结构体占五个字节。
可能你程序里面出现野指针了。 追踪一下代码吧,看看指针跑到哪里去了。估计是野指针,挂上调试器看一下堆栈应该能看得出。 很显然把问题最关键的东西没有写明白。。。。那就是“然后用Hardle_typedef去定义一个变量”,定义变量和使用部分怎么个使用法?要知道指针可是要初始化才能使用的。。。 你的两种定义,应该都是可以的。
关键不是定义出了问题,而是你用结构体的时候有问题。可是怎么用的,你又没有写。 同意楼上的看法,定义结构体中的指针,只要语法没有错误,编译通过,应该没有问题;问题在你怎么用的,也许变成了野指针,出问题了
页:
[1]
2