一个memset函数使用时的坑

平时使用memset函数都是用来初始化字符串,从来没有注意过它具体是怎么实现的,最近无意中发现原来这个函数里面还是有坑的。
我尝试用它来初始化整型数组
int array[10];
memset(array, 1, sizeof(a));
我原本是想将数组元素全部初始化为1,可是却是这样的:

一个memset函数使用时的坑

一开始不明白为什么会这样,查了以后才知道,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个整型)

一个memset函数使用时的坑

0001 0111 //第 3 个字节
0001 0111 //第 2 个字节
0001 0111 //第 1 个字节
0001 0111 //第 0 个字节

因为字符型元素只占用一个字节,所以对字符串用memset初始化直接简单的用 ch 对每个元素赋值就行了
再来看一个例子:

memset(array, 23, 10); //如果不足一个完整的int型怎么办?

一个memset函数使用时的坑

/* 10%4 == 2 第三个元素只有两个字节会被赋值*/
0000 0000//第 3 个字节
0000 0000//第 2 个字节
0001 0111//第 1 个字节
0001 0111//第 0 个字节 

平常使用memset函数注意规避这个坑足够了,如果你想了解更多关于memset函数的实现原理,请再去查看其它资料深入学习,我在此就不多做介绍了。

上一篇:算法训练 筛选号码


下一篇:SAP CRM订单系统设计时关于用户权限(User Authorization)的一些考虑