Fork me on GitHub

关于C++中memset方法的使用笔记

本文首发于我的个人Blog阿西BUG,欢迎大家批评指正

最近在用C++写服务端逻辑,在使用memset的时候出现了一些问题

现象

memset在对一个二维数组进行初始化的时候,因为某些原因需要初始化不为0,这就导致了问题的出现

先贴代码看

1
2
WORD 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方法

本文标题:关于C++中memset方法的使用笔记

文章作者:阿西BUG

发布时间:2018年07月16日 - 22:07

最后更新:2018年08月31日 - 10:08

原始链接:http://blog.92yu.win/2018/07/16/关于C-中memset方法的使用笔记/

许可协议: 署名-非商业性使用-禁止演绎 4.0 国际 转载请保留原文链接及作者。

阿西BUG wechat
福利干货铺(YM-TALK)-- 互联网福利干货大集合
Enjoy it ? Donate for it ! 欣赏此文?求鼓励,求支持!
>