c语言memset详解

article/2025/9/16 16:53:00

目录

    • 1 函数声明
      • 1.1功能
      • 1.2 例子
    • 2 常见错误
      • 2.1 搞反了 ch 和 n 的位置.
      • 2.2 过度使用memset
      • 2.3
    • 3 特殊例子

1 函数声明

void *memset(void *s, char ch, unsigned n);

1.1功能

将s所指向的某一块内存中的每个字节的内容全部设置为ch指定的ASCII值。块的大小由第三个参数指定,作用是在一段内存块中填充某个给定的值,它对较大的结构体或数组进行清零操作的一种最快方法。

1.2 例子

#include <stdio.h>
#include <string.h>
#include <stdio.h>
#include <memory.h>
int main(void)
{char buffer[] = "Hello world/n";printf("Buffer before memset: %s /n", buffer);memset(buffer, '*', strlen(buffer) );// //数组直接首地址传进去。 主要是对数组指针的修改!!因为可以被修改而const char int等这些不能被修改 和malloc 配套使用printf("Buffer after memset: %s /n", buffer);return 0;
}

在这里插入图片描述

2 常见错误

2.1 搞反了 ch 和 n 的位置.

一定要记住如果要把一个char a[20]清零,一定是 memset(a,0,20);
而不是 memset(a,20,0);

2.2 过度使用memset

有的程序员可能有某种心理阴影,惧怕未经初始化的内存,所以他们会写出这样的代码:

char buffer[20];
memset(buffer,0,sizeof(char)*20);
strcpy(buffer,"123");

这里的memset是多余的. 因为这块内存马上就被覆盖了,清零没有意义.

2.3

其实这个错误严格来讲不能算用错memset, 但是它经常在使用memset的场合出现

int some_func(struct something *a){ … … memset(a, 0, sizeof(a));} 

常见问题:

  1. 为何要用memset置零?memset(&Address,0,sizeof(Address));经常看到这样的用法,其实不用的话,分配数据的时候,剩余的空间也会置零的。
    答: 1.如果不清空,可能会在测试当中出现野值。你做下面的试验看看结果
#include "iostream.h"
#include "string.h"
#include <afx.h>
int main(){char buf[5];CString str;CString str1;CString str2;memset(buf,0,sizeof(buf));for(int i = 0; i<5; i++){str.Format("%d",buf[i]);str1 +=str ;}str2.Format("%d",str1);cout<<str2<<endl;system("pause");return 0;
}
此处设计c++版本的问题

这样写,有没有memset,输出都是一样
2.其实不然!特别是对于字符指针类型的,剩余的部分通常是不会为0的,不妨作一个试验,定义一个字符数组,并输入一串字符,如果不用memset实现清零,使MessageBox显示出来就会有乱码(0表示NULL,如果有,就默认字符结束,不会输出后面的乱码)
问: 如下demo是可以的,能把数组中的元素值都设置成字符1

#include <iostream>
#include <cstring>
using namespace std;
int main(){char a[5];memset(a,'1',5);for(int i = 0;i < 5;i++)cout<<a[i]<<" ";system("pause");return 0;
}
输出:1 1 1 1 1 请按任意键继续. . .

但是,如下程序想把数组中的元素值设置成1,却是不可行的

#include <iostream>
#include <cstring>
#include <windows.h>
using namespace std;
int main()
{int a[5];memset(a,1,20);//如果这里改成memset(a,1,5*sizeof(int))也不可以,因为memset按字节赋值。for(int i = 0;i < 5;i++)cout<<a[i]<<" ";system("pause");return 0;
}
输出:16843009 16843009 16843009 16843009 16843009 请按任意键继续. . .

问题是:
1,第一个程序为什么可以,而第二个不行?
因为第一个程序的数组a是字符型的,字符型占据内存大小是1Byte,而memset函数也是以字节为单位进行赋值的,所以你输出没有问题。而第二个程序a是整型的,使用 memset还是按字节赋值,这样赋值完以后,每个数组元素的值实际上是0x01010101即十进制的16843009。
2,不想要用for,或是while循环来初始化int a[5];能做到吗?(有没有一个像memset()这样的函数初始化)
如果用memset(a,1,20);(实际上与memset(a,1,5*sizeof(int))结果是一样的)就是对a指向的内存的20个字节进行赋值,每个都用ASCⅡ为1的字符去填充,转为二进制后,1就是00000001,占一个字节。一个INT元素是4字节,合一起就是0x01010101(十六进制),就等于16843009,就完成了对一个INT元素的赋值了。所以用memset对非字符型数组赋初值是不可取的!

对bool型数组赋值:

const int N = 11;
bool arr[N];
memset(&arr, 1, sizeof(bool) * N);Question  此处为啥需要&????????????

bool类型就是1或0.

例如有一个结构体Some x,可以这样清零:

memset(&x,0,sizeof(Some));//  X是单独的变量就要用&

如果是一个结构体的数组Some x[10],可以这样:

memset(x,0,sizeof(Some)*10); X是数组就不要用&,数组名就是地址喽

memset可以方便的清空一个结构类型的变量或数组。

如:struct sample_struct{char csName[16];int iSeq;int iType;};
对于变量struct sample_strcut stTest;
一般情况下,清空stTest的方法:stTest.csName[0]={'\0'};stTest.iSeq=0;stTest.iType=0;
用memset就非常方便:memset(&stTest,0,sizeof(struct sample_struct));
如果是数组:
struct sample_struct TEST[10];
则
memset(TEST,0,sizeof(struct sample_struct)*10);
另外:
如果结构体中有数组的话还是需要对数组单独进行初始化处理的。

3 特殊例子

给int型的数组复制时的几点注意:

一般常用的复制方式有:

int a[MAXN];
memset(a, 0, sizeof(a));//数组中的所有元素全为0
memset(a, -1, sizeof(a));//数组中的所有元素全为-1
memset(a, 127, sizeof(a));//数组中的所有元素全为2139062143(可以将其视为INF)

但切不可认为memset(a, 1, sizeof(a))后数组中的所有元素全为1了,这样数组的每个元素其值为: 16843009(因为memset函数是按一个字节一个字节来赋值的),。 每个都用ASCⅡ为1的字符去填充,转为二进制后,1就是00000001,占一个字节。一个INT元素是4字节,合一起是0000 0001,0000 0001,0000 0001,0000 0001,转化成十六进制就是0x01010101,就等于16843009

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cmath>
#include <cstring>
#include <string>using namespace std;
#define PI acos(-1.0)
#define EPS 1e-8
const int MAXN = 410000000;
const int INF = 2100000000;
int a[MAXN];int main()
{cout << a[0] << "  " << a[1] << endl;memset(a, -1, sizeof(a));cout << a[0]<< "  "  << a[1] << endl;memset(a, 0, sizeof(a));cout << a[0] << "  " << a[1] << endl;memset(a, 1, sizeof(a));cout << a[0] << "  " << a[1] << endl;memset(a, 2, sizeof(a));cout << a[0] << "  " << a[1] << endl;memset(a, 127, sizeof(a));cout << a[0] << "  " << a[1] << endl;return 0;
}输出:
0  0
-1  -1
0  0
16843009  16843009
33686018  33686018
2139062143  2139062143

参考链接:
https://blog.csdn.net/leonharetd/article/details/8666384


http://chatgpt.dhexx.cn/article/Rcw1Da0W.shtml

相关文章

【Java基础知识 9】序列化与反序列化

🍅 Java学习路线:搬砖工逆袭Java架构师 🍅 简介:Java领域优质创作者🏆、CSDN哪吒公众号作者✌ 、Java架构师奋斗者💪 🍅 扫描主页左侧二维码,加入群聊,一起学习、一起进步 🍅 欢迎点赞 👍 收藏 ⭐留言 📝 面试官:兄弟,说说你对transient的理解和感悟 …

详解序列化与反序列化

一、什么是序列化与反序列化 序列化时将对象状态转换为可保持或传输的形式的过程。序列化的补集是反序列化&#xff0c;反序列化是将流转换为对象。两个过程一起保证能够存储和传输数据。 .NET具有以下三种序列化技术&#xff1a; 1.二进制序列化 保持类型保真&#xff0c;这…

为什么要序列化?序列化你知道哪些?

凡事都要问为什么&#xff0c;在讲解序列化概念和原理前&#xff0c;我们先来了解一下为什么需要序列化。 为什么要序列化&#xff1f; 如果光看定义我想你很难一下子理解序列化的意义&#xff0c;那么我们可以从另一个角度来感受一下什么是序列化。 都玩过游戏么&#xff1…

说说什么是序列化,如何实现序列化

分析&回答 序列化机制 序列化机制&#xff08;包括序列化和反序列化&#xff09;的本质是用流将对象读到内存和写入外存。序列化机制的意义就是将对象脱离程序运行独立存在。通过网路或跨平台传输对象&#xff0c;传递的参数与返回值都实现序列化机制。实现序列化需要实现…

java序列化详解

一、序列化与反序列化 序列化&#xff1a;指堆内存中的java对象数据&#xff0c;通过某种方式把对存储到磁盘文件中&#xff0c;或者传递给其他网络节点&#xff08;网络传输&#xff09;。这个过程称为序列化&#xff0c;通常是指将数据结构或对象转化成二进制的过程。 即将对…

序列化和反序列化的底层实现原理是什么?

序列化和反序列化作为Java里一个较为基础的知识点&#xff0c;大家心里也有那么几句要说的&#xff0c;但我相信很多小伙伴掌握的也就是那么几句而已&#xff0c;如果再深究问一下Java如何实现序列化和反序列化的&#xff0c;就可能不知所措了&#xff01;遥记当年也被问了这一…

序列化和反序列化

我以前确实对序列化&#xff0c;乃至现在也是不是很熟悉&#xff0c;有时候查找资料&#xff0c;但依旧懵懵懂懂&#xff0c;不过还好遇到一个博主&#xff0c;确定写的挺好的&#xff0c;链接会放再底部 废话不多说&#xff0c;先看官网定义&#xff1a; 序列化 (Serializat…

我把序列化玩成了这样,吊锤了一波面试官

我们都知道&#xff0c;新建一个对象的时候实现 Serializeable 接口&#xff0c;但为什么要这么做&#xff1f;什么时候这样子做&#xff1f;这样子做会不会出现幺蛾子&#xff1f;阿粉一个三连差点把自己都问懵逼了…… 那接下来&#xff0c;大家就和阿粉一起简单了解一下这个…

什么是序列化? 如何实现(反)序列化 序列化的应用

1. 什么是序列化与反序列化&#xff0c;什么情况需要序列化1.1 序列化序列化是什么序列化的目的什么情况需要序列化 1.2 反序列化反序列化是什么反序列化的目的 2. Java中的序列化与反序列化2.1 如何实现序列化Java序列化的规定序列化的API实现(反)序列化的示例对象在硬盘上的存…

1.传输线驻波比

Transmission Line & Active Voltage Standing Wave Ratio 1.1 信号完整性概述 数字电路的出现极大地提高了电子产品的抗干扰能力&#xff0c;随着电路的工作频率不断提高&#xff0c;这种抗干扰能力逐渐显得有些“力不从心”。特别是在高速电路的范畴&#xff0c;“理想互…

驻波比,功率计原理,短波机驻波测量

文章内容转载自http://bbs.cqcqcq.com/thread-1627-1-1.html 衡量功率反射大小的量称为「反射系数」&#xff0c;常用Γ (音 gamma) 或ρ (音 rho) 表示。为了讨论简单起见&#xff0c;我们假设负载阻抗为纯阻性的。反射系数定义为&#xff1a; ρ (反射电压波) / (入射电压波)…

入射波反射波和驻波的特性推导

入射波反射波和驻波的基本推导 学习雷达过程中&#xff0c;发现阻抗匹配是一道迈不过去的坎&#xff0c;而阻抗匹配、能量传输与电压驻波比又有千丝万缕的联系&#xff0c;而电压驻波比则与反射波、入射波等相关的特性有关&#xff0c;于是写下此文章记录一下推导过程。 懒得正…

反射系数、驻波比、S参数之间的关系

反射系数、驻波比、S参数之间的关系&#xff01; 转载▼ 回波损耗(Return Loss): 入射功率/反射功率, 为dB数值 反射系数(Г): 反射电压/入射电压, 为标量 电压驻波比(Voltage Standing Wave Ration): 波腹电压/波节电压 S参数: S12为反向传输系数&#xff0c;也就是隔离。…

馈线中的VSWR电压驻波比

在射频信号馈线传输中&#xff0c;信号传输有一个概念&#xff1a;驻波比。 这个概念好理解&#xff0c;就是一个波进去&#xff0c;在终端由于不匹配形成反射波回来。 但是不是那么好想像&#xff0c;叠加后是啥模样的波形。 借助pythonmatplotlib可以方便模拟出来&#xf…

简单了解什么是驻波比?

驻波比全称为电压驻波比&#xff0c;又名VSWR&#xff0c;为英文Voltage Standing Wave Ratio的简写&#xff0c;在理解电压驻波比之前先要明白什么是“驻波”。 假设两个波长相同的波以相反的方向传播&#xff0c;绿线波朝着左方向旋转&#xff0c;蓝线波朝着右方向旋转&…

驻波比理解

VSWR(Voltage Standing Wave Ratio)代表电压驻波比。要完全理解这个术语&#xff0c;需要知道什么是“驻波”。 假设两个波长相同的波以相反的方向传播&#xff0c;如下所示。一个波表示为蓝线&#xff0c;它朝着正确的方向旋转。另一个波用绿线表示&#xff0c;它在左方向旋转…

电压驻波比,回波损耗,传输损耗,电压反射系数,功率传输,功率反射换算表

回波损耗(Return Loss)&#xff1a;入射功率/反射功率, 为dB数值反射系数(Г)&#xff1a;反射电压/入射电压, 为标量电压驻波比(Voltage Standing Wave Ration): 波腹电压/波节电压S参数&#xff1a;S12为反向传输系数&#xff0c;也就是隔离。S21为正向传输系数&#xff0c;也…

天线的驻波比

驻波比是衡量天线性能的重要参数之一,体现了天线向外界空间辐射能量的潜力。这是一个标量的参数,还有史密斯圆图(the Smith Chart)来衡量天线的阻抗特性,可以分析天线是感性还是容性的,并指明了调整天线的方向。 目录​ 一、什么是驻波比VSWR或者SWR

关于驻波比(VSWR)的详细解析

from滤波器 ◆ ◆ ◆ 文 | 滤波器&#xff08;ID:Filter_CN&#xff09; 驻波比&#xff08;VSWR&#xff09;用来检测天馈线系统、射频接头以及所有的连接到基站的射频设备的工作状态。VSWR过高会导致掉话、高误码率&#xff0c;而且由此引入的发射/接受功率的衰减会导致小…

射频回波损耗、反射系数、电压驻波比、S参数的含义与关系

以二端口网络为例&#xff0c;如单根传输线&#xff0c;共有四个S参数&#xff1a;S11&#xff0c;S12&#xff0c;S21&#xff0c;S22&#xff0c;对于互易网络有S12&#xff1d;S21&#xff0c;对于对称网络有S11&#xff1d;S22&#xff0c;对于无耗网络&#xff0c;有S11*S…