当前位置: 首页 > 编程笔记 >

C++中memset函数用法详解

袁元明
2023-03-14
本文向大家介绍C++中memset函数用法详解,包括了C++中memset函数用法详解的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了C++中memset函数用法。分享给大家供大家参考,具体如下:

功 能: 将s所指向的某一块内存中的每个字节的内容全部设置为ch指定的ASCII值,块的大小由第三个参数指定,这个函数通常为新申请的内存做初始化工作

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

程序示例:

#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) );
printf("Buffer after memset: %s\n", buffer);
return 0;
}

输出结果:

Buffer before memset: Hello world
Buffer after memset: ***********

编译平台:
Microsoft Visual C++ 6.0

也不一定就是把内容全部设置为ch指定的ASCII值,而且该处的ch可为int或者其他类型,并不一定要是char类型。例如下面这样:

char array[5] = {1,4,3,5,2};
for(int i = 0; i < 5; i++)
cout<<array[i]<<" ";
cout<<endl;
memset(array,"0",5*sizeof(int));
for(int k = 0; k < 5; k++)
cout<<array[k]<<" ";
cout<<endl;

输出的结果就是:
1 4 3 5 2
0 0 0 0 0

后面的表大小的参数是以字节为单位,所以,对于int或其他的就并不是都乘默认的1(字符型)了。而且不同的机器上int的大小也可能不同,所以最好用sizeof()。

要注意的是,memset是对字节进行操作,所以上述程序如果改为

int array[5] = {1,4,3,5,2};
for(int i = 0; i < 5; i++)
cout<<array[i]<<" ";
cout<<endl;
memset(array,1,5*sizeof(int));// 注意 这里与上面的程序不同
for(int k = 0; k < 5; k++)
cout<<array[k]<<" ";
cout<<endl;

输出的结果就是:
1 4 3 5 2
16843009 16843009 16843009 16843009 16843009

为什么呢?

因为memset是以字节为单位就是对array指向的内存的5个字节进行赋值,每个都用ASCII为1的字符去填充,转为二进制后,1就是00000001,占一个字节。一个INT元素是4字节,合一起就是00000001000000010000000100000001,就等于16843009,就完成了对一个INT元素的赋值了。

所以用memset对非字符型数组赋初值是不可取的!(????我好像看到有可以啊,又带确认)

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

memset( &x, 0, sizeof(Some) );

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

menset( x, 0, sizeof(Some)*10 );

memset函数详细说明

1. void *memset(void *s,int c,size_t n)

总的作用:将已开辟内存空间 s 的首 n 个字节的值设为值 c。

2. 例子

main(){
char *s="Golden Global View";
clrscr();
memset(s,'G',6);//貌似这里有点问题//
printf("%s",s);
getchar();
return 0;
}

【这个问题相当大,程序根本就运行不下去了,你这里的S志向的是一段只读的内存,而你memset又试图修改它,所以运行时要出错,修改办法char *s修改为char s[]】

3. memset() 函数常用于内存空间初始化。如:

char str[100];
memset(str,0,100);

4. memset()的深刻内涵:用来对一段内存空间全部设置为某个字符,一般用在对定义的字符串进行初始化为‘memset(a, '\0', sizeof(a));
memcpy用来做内存拷贝,你可以拿它拷贝任何数据类型的对象,可以指定拷贝的数据长度;例:

char a[100], b[50];
memcpy(b, a, sizeof(b));
//注意如用sizeof(a),会造成b的内存地址溢出。

strcpy就只能拷贝字符串了,它遇到'\0'就结束拷贝;例:

char a[100], b[50];
strcpy(a,b);

如用strcpy(b,a),要注意a中的字符串长度(第一个‘\0'之前)是否超过50位,如超过,则会造成b的内存地址溢出。

5. 补充:某人的一点心得

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);

或:

memset(TEST,0,sizeof(TEST));

希望本文所述对大家C++程序设计有所帮助。

 类似资料:
  • 主要内容:1、函数声明,2、函数调用,3、没有参数和返回值的函数,4、有参数但没有返回值的函数,5、有参数且有返回值的函数,6、类中的静态函数C# 中的函数(也可以称为方法)是一段具有签名(由函数名、参数类型和参数修饰符组成的函数信息)的代码块,可以用来实现特定的功能。一般情况下一个函数由以下几个部分组成: 访问权限修饰符:用于指定函数对一个类的可见性; 返回值类型:用于指定函数返回值的数据类型; 函数名称:用于进行函数调用的唯一名称; 参数列表:在调用函数时需要传递给函数的参数,参数列表是可选

  • 本文向大家介绍详解C语言中strpbrk()函数的用法,包括了详解C语言中strpbrk()函数的用法的使用技巧和注意事项,需要的朋友参考一下 头文件: strpbrk()函数检索两个字符串中首个相同字符的位置,其原型为: 【参数说明】s1、s2要检索的两个字符串。 strpbrk()从s1的第一个字符向后检索,直到'\0',如果当前字符存在于s2中,那么返回当前字符的地址,并停止检索。 【返回值

  • 本文向大家介绍详解C语言中index()函数和rindex()函数的用法,包括了详解C语言中index()函数和rindex()函数的用法的使用技巧和注意事项,需要的朋友参考一下 C语言index()函数:查找字符串并返回首次出现的位置 相关函数:rindex, srechr, strrchr 头文件:#include <string.h> 定义函数: 函数说明:index()用来找出参数s 字符

  • 本文向大家介绍详解C语言中telldir()函数和seekdir()函数的用法,包括了详解C语言中telldir()函数和seekdir()函数的用法的使用技巧和注意事项,需要的朋友参考一下 C语言telldir()函数:取得目录流的读取位置 头文件: 定义函数: 函数说明:telldir()返回参数dir 目录流目前的读取位置. 此返回值代表距离目录文件开头的偏移量返回值返回下个读取位置, 有错

  • 本文向大家介绍C++中inline函数详解,包括了C++中inline函数详解的使用技巧和注意事项,需要的朋友参考一下 本文主要记录了C++中的inline函数,也就是内联函数,主要记录了以下几个问题: 一、C++为什么引入inline函数? 主要目的:用它代替C语言中表达式形式的宏定义来解决程序中函数调用的效率问题。 C语言中的宏定义:#define ExpressionName(var1,va

  • 本文向大家介绍C语言函数语法详解,包括了C语言函数语法详解的使用技巧和注意事项,需要的朋友参考一下 1、概述         在C语言中,函数是来完成子程序或者某个模块的功能。有主程序或者其他函数调用,其他函数之间可以相互调用。同一函数可以被一个或多个函数任意次调用。 注意:     a、一个C程序有一个或多个程序模块组成,每一个程序模块作为一个源程序文件。一个源文件可以为多个C程序共用。    

  • 本文向大家介绍Python中flatten( )函数及函数用法详解,包括了Python中flatten( )函数及函数用法详解的使用技巧和注意事项,需要的朋友参考一下 flatten()函数用法 flatten是numpy.ndarray.flatten的一个函数,即返回一个一维数组。 flatten只能适用于numpy对象,即array或者mat,普通的list列表不适用!。 a.flatten

  • 本文向大家介绍SQLServer中merge函数用法详解,包括了SQLServer中merge函数用法详解的使用技巧和注意事项,需要的朋友参考一下 Merge关键字是一个神奇的DML关键字。它在SQL Server 2008被引入,它能将Insert,Update,Delete简单的并为一句。MSDN对于Merge的解释非常的短小精悍:”根据与源表联接的结果,对目标表执行插入、更新或删除操作。 M