专栏首页包子的书架memset的含义及作用

memset的含义及作用

  1. memset()函数原型是extern void *memset(void *buffer, int c, int count) buffer:为指针或是数组, c:是赋给buffer的值, count:是buffer的长度. 这个函数在socket中多用于清空数组.如:原型是memset(buffer, 0, sizeof(buffer)) Memset 用来对一段内存空间全部设置为某个字符,一般用在对定义的字符串进行初始化为‘ ’或‘/0’; 例:char a[100];memset(a, '/0', sizeof(a)); 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);

2.提问:“将s所指向的某一块内存中的每个字节的内容全部设置为ch指定的ASCII值,块的大小由第三个参数指定,这个函数通常为新申请的内存做初始化工作。用 法: void *memset(void *s, char ch, unsigned n);”

//“将s所指向的某一块内存中的每个字节的内容全部设置为ch指定的ASCII值”干什么?为什么说“这个函数通常为新申请的内存做初始化工作。”?

答:刚分配的内存空间,或者是被你用过的内存空间里面的数据是不固定的为了避免这些无用的数据给自己的程序带来影响,可以用memset把这些内存里面的数据置成某个数值一般情况下是置0,当然,如果你的程序不会受这些无用数据影响,就不用做这个工作了所谓“初始化”,当然是指将你定义的变量或申请的空间赋予你所期望的值,例如语句int i=0;就表明定义了一个变量i,并初始化为0;如果int j=5;就表明定义了一个变量j,并初始化为5。

   但是对于大块儿内存的分配,这种方法当然不行,例如int arr[100];定义了数组arr,包含100个元素,如果你写成int arr[100]=0;想将数组全部内容初始化为0,是不行的,连编译都不能通过。这种情况的初始化,有两种方法,一种是一个一个的初始化,如for(int i=0;i<100;i++)arr[i]=0;就完成了数组的初始化。另一种方法,就是使用memset:一个语句就够了--memset(arr,0,sizeof(int)*100);

各参数解释如下:arr是数组的首地址,0就是要讲这些地址的内容赋值为0,sizeof(int)求出int类型的长度,乘以100就表示arr数组的整个长度。

     当然,如果用malloc分配的内存,一般只能使用memset来初始化了,用第一种初始化方法明显不合适。

     例:char ch[10]
     比如memset(ch,0,8),就是把数组ch前八项置为零,后面的不一定为零。比如刚开始ch[1]='z',ch[8]='a',ch[9]='b',经过memset后,ch[1]为零了,而ch[8],ch[9]都不变.

3.memset函数详细说明 1)void *memset(void *s,int c,size_t n) 总的作用:将已开辟内存空间 s 的首 n 个字节的值设为值 c。

   2).memset() 函数常用于内存空间初始化。如:
       char str[100];
       memset(str,0,100);


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

       #include <mem.h>
       void* memset(void* s, int c, size_t n){
                 unsigned char* p = (unsigned char*) s;

                 while (n > 0) {
                            *p++ = (unsigned char) c;
                              --n;
                  }

                 return s;
       }




    memset()的函数, 它可以一字节一字节地把整个数组设置为一个指定的值。 memset()函数在mem.h头文件中声明,它把数组的起始地址作为其第一个参数,第二个参数是设置数组每个字节的值,第三个参数是数组的长度(字节数,不是元素个数)。其函数原型为:

void memset(void,int,unsigned);   其中void表示地址。   例如,下面的代码用数组做参数传递给标准函数memset(),以让其将数组设置成全0:     #include<mem.h>     void main()     {      int ia1[50];      int ia2[500];      memset(iai,0,50sizeof(int));      memset(ia2,0,500sizeof(int));      //     }   memset()的第一个实参是数组名,数组名作参数即数组作参数,它仅仅只是一个数组的起始地址而已。   在函数memset()栈区,从返回地址往上依次为第1,2,3个参数。第1个参数中的内容是main()函数中定义的数组ia1的起始地址。第2个参数是给数组设置的值(0),第3个参数是数组的长度(502)。函数返回时,main()函数的数组中内容全置为0。 栈 0 && image.height>0){if(image.width>=700){this.width=700;this.height=image.height*700/image.width;}}">

memset函数详细说明

1。void *memset(void *s,int c,size_t n) 总的作用:将已开辟内存空间 s 的首 n 个字节的值设为值 c。

2。例子 #include

void main(){ char *s="Golden Global View";

clrscr();

memset(s,'G',6); printf("%s",s);

getchar(); return 0; }  3。memset() 函数常用于内存空间初始化。如: char str[100]; memset(str,0,100);

4。memset()的深刻内涵:用来对一段内存空间全部设置为某个字符,一般用在对定义的字符串进行初始化为‘ ’或‘/0’;例:char a[100];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);

6。strcpy 原型:extern char *strcpy(char *dest,char *src); 用法:#i nclude 功能:把src所指由NULL结束的字符串复制到dest所指的数组中。 说明:src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。 返回指向dest的指针。 memcpy 原型:extern void *memcpy(void *dest, void *src, unsigned int count); 用法:#i nclude 功能:由src所指内存区域复制count个字节到dest所指内存区域。 说明:src和dest所指内存区域不能重叠,函数返回指向dest的指针。 memset 原型:extern void *memset(void *buffer, int c, int count); 用法:#i nclude 功能:把buffer所指内存区域的前count个字节设置成字符c。 说明:返回指向buffer的指针。

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的内存地址溢出。

str也可以用用个参数的strncpy(a,b,n)

========================================================

memset主要应用是初始化某个内存空间。 memcpy是用于copy源空间的数据到目的空间中。 strcpy用于字符串copy,遇到‘/0’,将结束。

如果你理解了这些,你应该知道他们的区别:例如你初始化某块空间的时候,用到memcpy,那么应该怎么写,是不是显得很笨。 int m[100] memset((void)m,0x00,sizeof(int)100);//Ok! memcpy((void)m,"/0/0/0/0....",sizeof(int)100);//it’s wrong.

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 加壳上碰到的问题

    最近由于公司项目原因,开始学习入手C++的加壳技术壳的编写,参考文献oBuYiSeng的博客里面详细的介绍了加壳的原理和开发步骤。 个人在开发的时候碰到了一些...

    包子388321
  • Glide的图片下载进度

    好久没有写简书了,都荒废了自己,今天整理了一下以前的代码和目前现有的项目代码,看了关于gradle图片下载进度的代码,这边整理了Glide3.7.0和Glide...

    包子388321
  • 简单的通过demo了解C++的基础语法笔记

    许久未碰C++的相关内容,已经有些被大脑的程序执行Lru算法了,导致近期在做NDK开发的时候,各种操作卡顿,决心还是回忆整理一下相关的基础知识。

    包子388321
  • LeetCode 222. Count Complete Tree Nodes(二分+位运算)

    题解:DFS 或者BFS都太low,我们可以用O(log(n)^2)的效率解决,n为节点个数,log(n)就是树的高度。

    ShenduCC
  • 面试前准备:二叉树高频面试题和答案

    面试中最常考的说法题主要是:数组、链表、二叉树、Map,深刻的理解上面二叉树算法题的解法思路,在面试中的二叉树题目就应该没有什么问题,祝大家面试顺利。

    五分钟学算法
  • LeetCode:111_Minimum Depth of Binary Tree | 二叉树的最小深度 | Easy

    要求:此题正好和Maximum Depth of Binary Tree一题是相反的,即寻找二叉树的最小的深度值:从根节点到最近的叶子节点的距离。 结题思路:和...

    CloudDeveloper
  • 二叉树实战 22 题,速度收藏吧!

    深刻的理解这些题的解法思路,在面试中的二叉树题目就应该没有什么问题,甚至可以怒他,哈哈。

    Java技术栈
  • 【数据结构与算法】一起搞定面试中的二叉树题目(二)

    用户1634449
  • 算法篇:树之树的高度

    https://leetcode-cn.com/problems/balanced-binary-tree/

    灰子学技术
  • 编程小技巧

    1.判断一个自然数是否是某个数的平方?(其实就是判断这个数一定是奇数相加的) 由于 (n+1)^2 =n^2 + 2n + 1, = ... = 1 +...

    猿人谷

扫码关注云+社区

领取腾讯云代金券