visual studio中问题提示截图:
代码部分展示:
struct tee_se_kdf_t
{
uint8_t seid[32];
uint32_t seidLen;
};
void fun(void)
{
u8 share[32] = {
0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F,
0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F
};
struct tee_se_kdf_t *kdf;
memcpy(kdf->seid, share, 32);
kdf->seidLen = 32;
tee_se_kdf(kdf);
}
1、问题提示:
在进行拷贝时候 memcpy(kdf->seid, share, 32)这里就提示:写入位置 0xCCCCCCCC 时发生访问冲突。
2、为什么出现问题:
其实写代码时候可能粗心大意,对平常的知识不能够在实际中运用到,写着写着就写成上面这样的代码。
3、问题原因分析:
定义了一个kdf的指针变量,没有去初始化指针;在使用的时候可能就指向的地址不是对的,再去对该指针指向的地方操作,可能就导致了访问地址异常。
4、解决办法:
可定义struct tee_se_kdf_t tempKdf变量,初始化定义的指针变量:struct tee_se_kdf_t *kdf = &tempKdf;就可以了。
或者就是不使用指针变量struct tee_se_kdf_t *kdf;直接定义了struct tee_se_kdf_t kdf来使用,就不会有指针未初始化的问题了。