本文首发于我的个人Blog阿西BUG,欢迎大家批评指正
最近在用C++写服务端逻辑,在使用memset的时候出现了一些问题
现象
memset在对一个二维数组进行初始化的时候,因为某些原因需要初始化不为0,这就导致了问题的出现
先贴代码看1
2WORD wLeftCardData[2][30];
memset(m_pLeftCardInfo->wLeftCardData[1], 4, sizeof(WORD)* 30);
得到的结果不是我想要的4, 而是1028
真是百思不得其解。。。。
memset原理
memset方法原型是: void *memset( void *buffer, int ch, size_t count );
功能:函数拷贝ch 到buffer 从头开始的count 个字符里, 并返回buffer指针。 memset() 可以应用在将一段内存初始化为某个值。
例如: memset( the_array, '\0', sizeof(the_array) );
这是将一个数组的所有分量设置成零的很便捷的方法。
错误分析
memset方法是按照字节进行赋值的
在我的错误代码中,WORD类型占两个字节,那么memset就会分别对WORD的高字节和低字节分别填充4这个值,那么每个WORD的值就相当于0x4040 = 1028
总结
- memset函数按字节对内存块进行初始化
所以不能用它将int数组初始化为0和-1之外的其他值(除非该值高字节和低字节相同) memset(void *s, int ch,size_tn);
中ch实际范围应该在0~~255,因为该函数只能取ch的后八位赋值给你所输入的范围的每个字节
比如int a[5]赋值memset(a,-1,sizeof(int )5)与memset(a,511,sizeof(int )5) 所赋值的结果是一样的都为-1;
因为-1的二进制码为(11111111 11111111 11111111 11111111),而511的二进制码为(00000000 00000000 00000001 11111111)后八位都为(11111111)
替代方案
那么,有没有什么好的方法替代memset对变量进行非0/1的初始化呢?
答案是有的
可以参考std::fill
方法