strcpy strncpy 区别

    strncpy(sl.fcc1,(rqst->data)+p,2);      strncpy(sl.fcc2,(rqst->data)+p+3,2);    strncpy(sl.fltn,(rqst->data)+p+6,4);
    strncpy(sl.flts,(rqst->data)+p+11,1);   strncpy(sl.fssd,(rqst->data)+p+13,7);   strncpy(sl.bgdt,(rqst->data)+p+21,7);
    strncpy(sl.eddt,(rqst->data)+p+29,7);

typedef struct SELOH
{
    char   fcc1[3];
    char   fcc2[3];
    char   fltn[5];
    char   flts[2];
    char   fssd[8];
    char   type[28][3];
    char   bgdt[8];
    char   eddt[8];

    char   *sqlstep;
    int    sqlcode;
}   SELOH;

第一种情况:
char*p="howareyou?";
char name[20]="ABCDEFGHIJKLMNOPQRS";


strcpy(name,p);//name改变为"howareyou?OPQRS"                  // 错误!
strncpy(name,p,sizeof(name))//name改变为"howareyou?"        // 正确!

第二种情况:
char *p="howareyou?";
char name[20];

strcpy(name,p);//name改变为"howareyou?未知字符"                // 错误!
name[sizeof(name)-1]='\0'//和上一步组合,得到正确的结果!
strncpy(name,p,sizeof(name));//name改变为"howareyou?"      // 正确!

第三种情况:
char*p="howareyou?";
charname[10];

strcpy(name,p);//name改变为"howareyo"                         //无结束符'\0',错误!
name[sizeof(name)-1]='\0'//和上一步组合,弥补结果。但要注意,字符传递错误!
strncpy(name,p,sizeof(name));//和单纯的一步strcpy结果一样!

总结:

strcpy
如果源长>目标长,则将源长中等于目标长的字符拷贝到目标字符串
如果源长<目标长,则源长全部拷贝到目标字符串,不包括'\0'
strncpy
如果目标长>指定长>源长,则将源长全部拷贝到目标长,自动加上'\0'
如果指定长<源长,则将源长中按指定长度拷贝到目标字符串,不包括'\0'
如果指定长>目标长,error happen

memcpy strcpy strncpy lstrcpy lstrncpy wstrcpy, memmove

memcpy
原型 extern void *memcpy(void *dest, void *src, unsigned int count);
功能:由src所指内存区域复制count个字节到dest所指内存区域。
说明:src和dest所指内存区域不能重叠,函数返回指向dest的指针。
出错可能:
1,dest buffer 不够大,不能容纳src的内容。
2,count 大于 src buffer长度, 造成拷贝越界到别的内容。
3,dest 和 src 有内存重叠。
例如,array[] = {0,1,2,3,4}
/* array 变成 {0,1,0,1,0},而不是 {0,1,0,1,2}*/
memcpy(&array[2], &array[0], 3);

strcpy
原型:extern char *strcpy(char *dest,char *src);
功能:把src所指由NULL结束的字符串复制到dest所指的数组中。
说明:src和dest所指内存区域不可以重叠且,dest必须有足够的空间来容纳src的字符串。返回指向dest的指针。
出错可能:
1,src 和 dest有重叠
2,dest空间不足以来容纳src的字符串
3,用之前为初始化数组
char* p="I love pizza!";
char name[20]="ABCDEFGHIJKLMNOPQRS";
strcpy(name,p); //name变为"I love pizza! OPQRS " 错!
4,字符串中有中文字符,中文字符占两个字节。
char* p = "ABCDEFGHIJKLMNOPQR啊";
strcpy(name, p);

strncpy
原型:extern char *strncpy(char *dest, char *src, int n);
功能:把src所指由NULL结束的字符串的前n个字节复制到dest所指的数组中。
说明:
        如果src的前n个字节不含NULL字符,则结果不会以NULL字符结束。
        如果src的长度小于n个字节,则以NULL填充dest直到复制完n个字节。
        src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。
        返回指向dest的指针。
出错可能:
1,src 和 dest 重叠
2,dest 不足以容纳 src的字符串
3,安全性高于strcpy,但是当dest长度大于src长度,两者出同样的错误。字符串截断,没有\0.

lstrcpy lstrncpy
原型: LPTSTR lstrcpy(LPTSTR dest, LPTSTR src);
      LPTSTR lstrcpy(LPTSTR dest, LPTSTR src, int count);
功能:类似于strcpy 和strncpy
说明:这是windows API,只能用于windows平台。和标准C函数strcpy,strncpy区别在于,如果定义了unicode,lstrcpy() 就变成 wstrcpy()完成double-byte unicode字符的拷贝。

wstrcpy
原型:wchar_t *wstrcpy (wchar_t *ws1,wchar_t *ws2 );
     wchar_t *wstrncpy(wchar_t *ws1,wchar_t *ws2,int n );
功能:类似于strcpy 和strncpy,但是作用于宽字符,
说明:所在头文件是<wstring.h>,而不是<string.h>
出错可能:
原理类似窄符拷贝

memmove
原型:extern void *memmove(void *dest, const void *src, unsigned int count);
功能:由src所指内存区域复制count个字节到dest所指内存区域。
说明:src和dest所指内存区域可以重叠,但复制后src内容会被更改。函数返回指向dest的指针。由此可见,用memmove 比memcpy安全的多!

你可能感兴趣的:(RCP)