今天调试发现一个自己之前没怎么主要的问题,不合法的指针运算会产生内存溢出错误。
例如:定义有如下结构体:
struct Example{
INT8U * DataPtr;
INT8U length;
}example;
//我想在example尾部增加10个0,做了如下运算:
memset((INT8U*)(&example)+sizeof(example),0,10);
//这样的代码是非法的,虽然有可能在首次运行时没有问题,但是全速运行必会报错,死掉,这是对内存操作非法的原因。
分析:对于example尾部往后的空间是未经分配的或者已经分配的,在进行指针加法运算之后,对该部分内存进行操作就很有可能产生内存访问错误。
仅此Mark一个,希望以后能够避免。