平时使用memset函数都是用来初始化字符串,从来没有注意过它具体是怎么实现的,最近无意中发现原来这个函数里面还是有坑的。
我尝试用它来初始化整型数组
int array[10];
memset(array, 1, sizeof(a));
我原本是想将数组元素全部初始化为1,可是却是这样的:
一开始不明白为什么会这样,查了以后才知道,void *memset(void *s, int ch, size_t n)并不是直接把 ch 的值赋到 s 的元素上去。
我们先来看看这个神奇的数字:16843009 的二进制表示形式是什么:
16843009(10) = 0000 0001 0000 0001 0000 0001 0000 0001(2)
有没有看出什么规律?
也许你已经看出来了,为了更明显一些,我们换个角度看:
0000 0001 //第 3 个字节
0000 0001 //第 2 个字节
0000 0001 //第 1 个字节
0000 0001 //第 0 个字节
原来memset是以字节为单位对每个元素赋值的
再来个例子:
memset(array, 23, 16); //此处只对 16 个字节元素赋值(即4个整型)
0001 0111 //第 3 个字节
0001 0111 //第 2 个字节
0001 0111 //第 1 个字节
0001 0111 //第 0 个字节
因为字符型元素只占用一个字节,所以对字符串用memset初始化直接简单的用 ch 对每个元素赋值就行了
再来看一个例子:
memset(array, 23, 10); //如果不足一个完整的int型怎么办?
/* 10%4 == 2 第三个元素只有两个字节会被赋值*/
0000 0000//第 3 个字节
0000 0000//第 2 个字节
0001 0111//第 1 个字节
0001 0111//第 0 个字节
平常使用memset函数注意规避这个坑足够了,如果你想了解更多关于memset函数的实现原理,请再去查看其它资料深入学习,我在此就不多做介绍了。