函数介绍
void *memset(void *s, char ch,
size_t
n);
函数解释:将s中前n个字节 (typedef unsigned int size_t)用 ch 替换并返回 s 。
常见错误
第一: 搞反了 ch 和 n 的位置.
一定要记住如果要把一个char a[20]清零,一定是 memset(a,0,20);
而不是 memset(a,20,0);
第二: 过度使用memset,我想这些
程序员可能有某种心理阴影,他们惧怕未经初始化的内存,所以他们会写出这样的代码:
1
2
3
|
char
buffer[20];
memset
(buffer,0,
sizeof
(
char
)*20);
strcpy
(buffer,
"123"
);
|
这里的memset是多余的. 因为这块
内存马上就被覆盖了,清零没有意义.
第三: 其实这个错误严格来讲不能算用错memset,但是它经常在使用memset的场合出现
1
2
3
4
5
6
7
|
int
some_func(
struct
something *a)
{
…
…
memset
(a,0,
sizeof
(a));
…
}
|
自己理解:
memset()的深刻内涵:用来对一段内存空间全部设置为某个字符,一般用在对定义的字符串进行初始化为‘ ’或‘/0’;例:char a[100];memset(a, '/0', sizeof(a));
memset与strcpy的区别:(1)
memcpy用来做内存拷贝,你可以拿它拷贝任何数据类型的对象,可以指定拷贝的数据长度;例:char a[100],b[50]; memcpy(b, a, sizeof(b));注 意如用sizeof(a),会造成b的内存地址溢出。(2)strcpy就只能拷贝字符串了,它遇到'/0'就结束拷贝;例:char a[100],b[50];strcpy(a,b);如用strcpy(b,a),要注意a中的字符串长度(第一个‘/0’之前)是否超过50位,如超过,则会造成b的内存地址溢出。