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

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

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

现象

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

先贴代码看

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方法

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值