news 2026/5/7 5:37:18

menset的使用方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
menset的使用方法

menset的使用方法

#include <cstring> // 必须包含这个头文件! memset(目标内存地址, 填充值, 填充的字节数);

填充值只能是「单字节值」

memset是按字节填充,所以:

  • ✅ 填充0:完全没问题(所有类型数组清空都能用);
  • ❌ 填充1:不要这么做!比如int占 4 字节,填充1会变成0x01010101(十进制 16843009),不是你想要的1
  • 总结:memset几乎只用来填充0(清空)或-1(特殊场景),其他值慎用。

为什么只能0和-1呢

核心原因是0 和 1 在二进制中的表示形式不同,加上memset是「按字节填充」,导致填充 0 时所有类型都能得到预期结果,填充 1 时只有单字节类型(如char)符合预期,多字节类型(如int)会出错。我用通俗的方式拆解这个逻辑:

一、先搞懂两个基础概念

1. 字节与多字节类型的存储

计算机中:

  • 1 个字节 = 8 位二进制(00000000 ~ 11111111);
  • char类型占 1 字节,int类型通常占 4 字节(不同编译器可能是 2/8 字节,以 4 字节为例);
  • 多字节类型(如int)的存储是「多个字节拼接」,比如int a = 1,在内存中存储为:

    plaintext

    字节1(低地址) | 字节2 | 字节3 | 字节4(高地址) 00000001 | 00000000 | 00000000 | 00000000
    (小端存储,绝大多数系统的默认方式)
2. memset 的填充规则

memset不关心数组的类型,只把目标内存拆成「一个个独立的字节」,每个字节都填充成你指定的值,比如:

  • 填充值是0→ 每个字节都变成00000000
  • 填充值是1→ 每个字节都变成00000001

二、为什么填充 0 没问题?

int类型为例(4 字节),memset给每个字节填0

plaintext

字节1 | 字节2 | 字节3 | 字节4 00000000 | 00000000 | 00000000 | 00000000

拼接后整个int的值就是0(十进制),完全符合 “清空数组为 0” 的预期。

不管是char(1 字节)、int(4 字节)、long long(8 字节),填充 0 时每个字节都是 0,拼接后整体值就是 0 → 所以所有类型数组清空都能用memset填 0。

三、为什么填充 1 会出错?

还是以int类型(4 字节)为例,memset给每个字节填1(二进制00000001):

plaintext

字节1 | 字节2 | 字节3 | 字节4 00000001 | 00000001 | 00000001 | 00000001

把这 4 个字节拼接成int值:

  • 二进制:00000001 00000001 00000001 00000001
  • 十六进制:0x01010101
  • 十进制:1*2^24 + 1*2^16 + 1*2^8 + 1 = 16843009

这显然不是你想要的1!只有char类型(1 字节)填充 1 时,结果才是1(因为只有 1 个字节,没有拼接问题)。

四、为什么 - 1 是特例(可以填充)?

这是因为-1在二进制中是「全 1」(补码存储规则):

  • 1 字节的-111111111
  • 4 字节的-111111111 11111111 11111111 11111111

memset填充-1时,每个字节都变成11111111,拼接后不管是 1 字节 / 4 字节 / 8 字节类型,整体值都是-1→ 所以填充-1也是符合预期的。

五、总结(核心要点)

填充值单字节类型(char)多字节类型(int/long long)能否用 memset 填充
0结果为 0(正确)结果为 0(正确)✅ 可以
1结果为 1(正确)结果为 0x01010101(错误)❌ 不可以
-1结果为 - 1(正确)结果为 - 1(正确)✅ 可以

简单记:memset只适合填充「所有字节都相同」的值,只有0-1满足这个条件(0 是全 0,-1 是全 1),其他值(如 1、2、100)的多字节拼接结果都不符合预期。

对你的代码场景来说,只需要用memset填 0 清空数组就够了,这也是memset最常用、最安全的用法~

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/5 3:39:46

大厂迷思:为什么顶级工程师会产出难以维护的代码

当你终于通过几轮严苛的技术面试&#xff0c;加入一家享有盛誉的大型科技公司时&#xff0c;往往会对即将接触的代码库抱有极高的期待。你想象着整洁的架构、清晰的文档以及如教科书般完美的逻辑实现。然而现实往往极具冲击力&#xff1a;你所看到的可能是一个由无数补丁堆叠、…

作者头像 李华
网站建设 2026/5/5 3:39:44

多级缓存必要性

Java多级缓存设计&#xff1a;应对微博明星官宣的高并发场景 一、多级缓存原理与必要性 1.1 为什么需要多级缓存&#xff1f; 单级缓存的问题&#xff1a; 性能瓶颈&#xff1a;所有请求都打到同一缓存层&#xff0c;压力集中容错性差&#xff1a;缓存层故障直接影响整体可…

作者头像 李华
网站建设 2026/5/3 19:18:49

attn_scores注意力分计算-记录

querys 是 2*6*2&#xff0c;keys也是2*6*2 attn_scores querys keys.transpose(1,2)attn_scores 最终维度是 266&#xff1b;数值上是两个矩阵的批量矩阵乘法结果&#xff0c;每个样本对应一个 66 的注意力分数矩阵 transpose(1,2) 交换 keys 的第 1 维和第 2 维&#xff1…

作者头像 李华
网站建设 2026/5/1 13:35:29

为什么标准化要用均值0和方差1?

为什么标准化要把均值设为0、方差设为1&#xff1f; 先说均值。均值就是平均数&#xff0c;所有观测值加起来除以个数。 μ是均值&#xff0c;n是数据点总数&#xff0c;xᵢ是每个数据点&#xff0c;所以均值就是数据的重心位置。比如均值是20&#xff0c;那20就是平衡点。这…

作者头像 李华
网站建设 2026/5/4 13:35:54

人群仿真软件:Vadere_(2).Vadere基本操作与界面

Vadere基本操作与界面 启动Vadere 启动过程 Vadere是一款基于Java的人群仿真软件&#xff0c;可以通过以下步骤启动&#xff1a; 安装Java环境&#xff1a;确保您的计算机上安装了Java运行环境&#xff08;JRE&#xff09;或Java开发工具包&#xff08;JDK&#xff09;。您可…

作者头像 李华