memset是C++中按字节初始化内存的函数,适用于字符数组清零、简单结构体初始化等场景,但不可用于类对象或非0/-1的多字节类型赋值,否则会导致数据错误或程序崩溃。

在C++中,memset 是一个来自
函数原型与基本用法
memset 的函数原型如下:
void* memset(void* ptr, int value, size_t num);- ptr:指向要填充的内存块的指针
- value:要设置的值(以 int 形式传入,但实际按字节处理)
- num:要设置的字节数
该函数会将从 ptr 开始的 num 个字节都设置为 value & 0xFF(即只取低8位)。
只能按字节赋值,不能直接初始化非字符类型数组
memset 按字节操作,因此它不适合用来初始化 int、double 等多字节数据类型的数组,除非你要设置的值是 0 或 -1。
立即学习“C++免费学习笔记(深入)”;
例如:
int arr[10];memset(arr, 0, sizeof(arr)); // 正确:全部设为0
memset(arr, -1, sizeof(arr)); // 正确:每个字节设为0xFF,int 变成 -1
memset(arr, 1, sizeof(arr)); // 错误!不是把每个元素设为1,而是每个字节设为1,结果不是预期的1
因为整型占4字节,memset(arr, 1, ...) 会使每个字节变成 0x01,最终每个 int 的值是 0x01010101 = 16843009,而非 1。
慎用于类对象或包含指针的结构体
对含有指针成员、虚函数(即有虚表)或复杂成员的类对象使用 memset 非常危险。
- 会破坏虚函数表指针,导致后续调用虚函数崩溃
- 会将指针成员置为 NULL 或随机值,造成内存泄漏或非法访问
- 违反了构造函数/析构函数语义,可能引发未定义行为
例如:
class MyClass {public:
virtual void func() {}
private:
int* data;
};
MyClass obj;
memset(&obj, 0, sizeof(obj)); // 危险!虚表指针被破坏
应使用构造函数或赋值操作来初始化对象,而不是 memset。
正确使用场景举例
memset 最适合用于以下情况:
- 清零字符数组:char buffer[256]; memset(buffer, 0, sizeof(buffer));
- 初始化结构体为零(仅当不含指针或类对象时):struct Data d; memset(&d, 0, sizeof(d));
- 临时缓冲区重置,如网络通信中的包缓冲区
更现代的C++推荐使用 std::fill 或 std::zero_memory(C++20起)等类型安全的方式替代。
基本上就这些。记住:memset 是面向字节的底层操作,不是通用初始化工具。用对了高效,用错了隐患大。










