memset,memcpy,strcpy 的区别

来源:互联网 发布:linux rm rf 恢复 编辑:程序博客网 时间:2024/05/07 16:52

.函数原型
   strcpy
   extern char *strcpy(char *dest,char *src);
   #include <string.h>
  
功能:把src所指由NULL结束的字符串复制到dest所指的数组中
  
说明:srcdest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。
  
返回指向dest的指针

memcpy
extern void *memcpy(void *dest,void *src,unsigned int count);
#include <string.h>
  
功能:由src所指内存区域复制count个字符串到dest所指内存区域.
  
说明:srcdest所指内存区域不能重叠,函数返回指向dest的指针
.
  
   memset
   extern void *memset(void *buffer,int c,int count);
   #include <string.h>
  
功能:把buffer所指内存区域的前count个字节设置成字符
c
  
说明:返回指向buffer的指针
.


 

.区别
    memset
用来对一段内存空间全部设置为某个字符,一般用于在对定义的字符串初始化为' '或者'/0';
   
: char a[100];
          memset(a,'/0',sizeof(a));
   
   memcpy
是用来做内存拷贝,可以用来拷贝任何数据类型的对象,可以指定拷贝的数据长度;

  
:
           char a[100],b[50];
           memcpy(b,a,sizeof(b));   //
注意:如果使用sizeof(a),会造成内存溢出

   mem
是一段内存,他的长度,必须自己记住.memcpy是见着什么拷贝什么。
   
    strcpy
就只能拷贝字符串,它遇到'/0'就结束拷贝;
     
例:char a[100],b[50];
              strcpy(a,b);
             
如用strcpy(b,a)要注意a中的字符串长度(第一个'/0'之前) 是否超过50,如果超过,则会造成b

内存溢出.它是不会拷贝'/0'的,所以一般还有加一个语句:
              *a='/0';
  
.使用技巧
      memset 可以方便的清空一个数据结构的变量或数组.
     
:
        struct sample_struct
       {
              char csName[16];
              int iSeq;
              int iType;
       };
      
对于变量

       struct sample_struct stTest;
      
一般情况下,初始化stTest的方法:
        stTest.csName[0]='/0';
        stTest.iSeq=0;
        stTest.iType=0;
   
而用
memset:
       memset(&stTest,0,sizeof(struct sample_struct));
   
如果是数组
:
    struct sample_struct TEST[100];
    memset(TEST,0,sizeof(struct sample_struct)*100);

 

 

strcpy

原型:extern char *strcpy(char *dest,char *src);
用法:
#include <string.h>
功能:把src所指由NULL结束的字符串复制到dest所指的数组中。

说明:srcdest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。
   
返回指向dest的指针。

例:char a[100],b[50];strcpy(a,b);如用strcpy(b,a),要注意a中的字符串长度(第一个‘/0’之前)是否超过50位,如超过,则会造成b的内存地址溢出。

memcpy
原型:extern void *memcpy(void *dest, void *src, unsigned int count);
用法:
#include <string.h>
功能:由src所指内存区域复制count个字节到dest所指内存区域。

说明:srcdest所指内存区域不能重叠,函数返回指向dest的指针。可以拿它拷贝任何数据类型的对象。

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

memset
原型:extern void *memset(void *buffer, int c, int count);
用法:
#include <string.h>
功能:把buffer所指内存区域的前count个字节设置成字符c

说明:返回指向buffer的指针。用来对一段内存空间全部设置为某个字符。

举例: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);

对这个问题有疑问,不是对函数的疑问,而是因为没有弄懂memstr的区别。
mem
是一段内存,他的长度,必须你自己记住
str
也是一段内存,不过它的长度,你不用记,随时都可以计算出来
所以memcpy需要第三个参数,而strcpy不需要。

原创粉丝点击