memset()函数 详解

今天做题卡在MEMSET函数的使用上了,本来以为int a[100]; memset(a, MAX,sizeof(a));就是将a数组全部赋值为MAX,现在才知道他的填充是以字节为单位,一般用于对字符型变量的初值进行赋值.

更详细的解说见百度百科 --> http://baike.baidu.com/view/982208.htm 

 

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的指针。

转载自:http://www.cnblogs.com/xiaolongchase/archive/2011/10/22/2221326.html

memset、sizeof知多少?  

2010-05-25 17:41:33|  分类: VC |  标签: |字号 订阅

      尽管我们大家在平时的代码编写中经常用到函数memset和运算符sizeof,但是大家对这它们又真正的理解了多少呢?今天有时间,也很久没有更新博客了,就自己的见解和实际的使用中可能出现的问题做一个简单的总结:

1. memset

     void *memset( void *dest, int c, size_t count );

     所需头文件"memory.h",主要功能是将目标指针dest对应count个字节内存空间的值初始化为c,这个函数的功能虽然看起来很简单,但是对于初始化分配结构体、数组等类型对应内存空间时,它的效率是极高的。那么看到上面的说明,我们基本了解了memset可以对分配内存进行初始化。下面请看初始化实例,我们将长度为256的不同类型和不同分配方式下的内存空间对应值赋值为1,下面分别采用4种方式进行实现:

     #include "stdio.h"

     #include "memory.h"

     void main()

     {

             //方式1

             //静态数组char型赋值成1

             char buffer[256];

             memset(buffer, 1, sizeof(buffer));

             ///

             //方式2

             //静态数组int型赋值成1

             int buffer[256];

             memset(buffer, 1, sizeof(buffer));

             ///

            //方式3

            //动态数组char型赋值成1

             char *buffer;

             buffer = new char[256];

             memset(buffer, 1, sizeof(buffer));

             ///

             //方式4

             //动态数组int型赋值成1

             int *buffer;

             buffer = new int[256];

             memset(buffer, 1, sizeof(buffer));

             //

     }

     那么,上面4种方式运行之后是否实现了我们的要求呢?

     运行上述四种方式对应代码,通过调试我们可以发现,只有方式1才实现了我们的目标,其它3种方式都没有达到我们的要求,那是为什么呢?

     看看上面红色部分标记的语句,我们不难发现,其实memset函数其实是针对字节进行快速初始化的,也就是说它不为管你的内存是char型还是int型,在它看来,你只用告诉它需要初始化内存空间的字节长度,它就将对应的内存空间对应的每个字节全部初始化成相同的整数值,所以方式2操作后buffer对应的内存空间的值就变成了

     buffer[0]~buffer[255]

     0x0101  0x0101 0x0101 .......................0x0101

     所以方式2实际上是将buffer数组里面的每一个元素初始化成了0x0101,即257

     那么方式3和4的错误又在什么地方呢,按理说方式3应该是正确的才对,在这里,我要说,可能大家又忽视了sizeof运算符的用法了,这也是我在一次代码的调试过程中发现自己犯过同样的错误,sizeof是获取变量或者类型(通常是结构体)的字节存储空间大小,所以自然的,方式3和方式4中sizeof(buffer)的值均为4,可能在不同编译环境中,值可能不同,在vc环境下是4,因为此时的buffer只是一个指针变量,简单的说来,buffer也是一个变量,只不过这个变量比较特殊--指针变量,在vc中,指针变量一般用4个字节来存储,所以它们最终操作后的内存空间实际上是将buffer指向的100个字节的char型和int型内存空间对应的前4个字节初始化成1,所以操作后:

     方式3:

     buffer[0] = buffer[1] = buffer[2] = buffer[3] = 1,其余元素未初始化

     方式4:

     buffer[0] = buffer[1] = 0x0101,其余未初始化(如有疑问,请参考方式2的分析)

     所以,虽然memset初始化内存好用,但是我们也不得不注意到,初始化其实是针对字节而言的,一旦出现对非字节内存变量赋值时,我们要谨记,此时的memset只能作为初始化为0操作的功能函数,在实际的代码编写中,一般而言,为了快速对申请的内存进行初始化,我们一般也用memset进行内存对应值初始化为0的操作。

     下面简单说下sizeof运算符,请看下面一段代码,执行之后的输出是多少?

     #include "stdio.h"
     struct TESTSTRUCT
     {
           int *m_pData;    
           unsigned char m_nType; //自动对齐到int
           int m_nCount;
           float m_fScore;
           double m_fAverage;
           bool m_bAllowed;   //自动对齐到double
     };

     void main()
     {
           printf("%d\n", sizeof(TESTSTRUCT));
     }

 

转载自:http://yiyunscu.blog.163.com/blog/static/36263320201042554133370/

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值