**使用memset时遇到的问题分享**
直接看代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef unsigned char u8;
int arr[20];
int main()
{
u8 i=0;
for(i=0;i<20;i++){//添加数组arr数据
arr[i] = i;
}
for(i=0;i<20;i++){
printf("%02d ",arr[i]);//打印数组arr数据
}
printf("\r\n");
#if 1
memset(arr,0,sizeof(arr)/sizeof(arr[0]));//使用memset数据清零操作
printf("len:%d\r\n",sizeof(arr)/sizeof(arr[0]));
#else
memset(arr,0,sizeof(arr));
printf("len:%d\r\n",sizeof(arr));
#endif
for(i=0;i<20;i++){
printf("%02d ",arr[i]);//打印清零处理后结果
}
printf("\r\n");
return 0;
}
打印结果1:
00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19
len:20
00 00 00 00 00 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19
更改使用 memset(arr,0,sizeof(arr));
#if 0
memset(arr,0,sizeof(arr)/sizeof(arr[0]));//使用memset数据清零操作
printf("len:%d\r\n",sizeof(arr)/sizeof(arr[0]));
#else
memset(arr,0,sizeof(arr));
printf("len:%d\r\n",sizeof(arr));
#endif
打印结果2:
00 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19
len:80
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
从如上两种结果可以看出,使用memset函数
extern _ARMABI void *memset(void * /*s*/, int /*c*/, size_t /*n*/) __attribute__((__nonnull__(1)));
对数据进行操作时,size_t 表示需处理的数据长度,而这个长度是按照字节单位进行处理的,由于我使用的数组类型是int ,每个数组成员占用都是4个字节,从打印结果1看出,由于处理的数据长度只有20字节,所以进行清零操作就只有数组下标0~4,即5个数组成员的数据进行了清零操作;若我们的数组类型是u8(unsigned char),那么上面两处的打印结果是一样的。
故我们在使用memset操作时,size_t 这个形参是对字节数操作,而不是处理对象数组的长度,故使用如下方式:
memset(arr,0,sizeof(arr));