字符处理函数的区别

转载 2012年03月23日 00:33:34

一、strcpy VS strncpy

奇怪的现象

第一种情况:

char* p="how are you ?";
char name[20]="ABCDEFGHIJKLMNOPQRS";

strcpy(name,p);   //name改变为"how are you ?\0OPQRS "     ====>错误!
strncpy(name,p,sizeof(name))    //name改变为"how are you ?      "       ====>正确!

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

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

第三种情况:
char* p="how are you ?";
char name[10];

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

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

二、memcpy memmove strcpy strncpy  

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}
memcpy(&array[2], &array[0], 3);//内存重叠

memmove

原型:extern void *memmove(void *dest, const void *src, unsigned int count);
功能:由src所指内存区域复制count个字节到dest所指内存区域。

说明:src和dest所指内存区域可以重叠,但复制后src内容会被更改。函数返回指向dest的指针。

          由此可见,用memmove 比memcpy安全的多!

strcpy
原型:extern char *strcpy(char *dest,char *src);
功能:把src所指由'\0'结束的字符串复制到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所指由'\0'结束的字符串的前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.

memmove
原型:extern void *memmove(void *dest, const void *src, unsigned int count);
功能:由src所指内存区域复制count个字节到dest所指内存区域。

说明:src和dest所指内存区域可以重叠,但复制后src内容会被更改。

            函数返回指向dest的指针。由此可见,用memmove 比memcpy安全的多!

三、经典实例
 char s[]="123456789";
 char d[]="123";
 strcpy(d,s);
 结果:d="123456789",s="56789"
 原因:程序栈的存放规则是先声明,先存放,栈的存放情况
             栈底-------------------------->栈顶
     \0987654321\0321
             strcpy是以\0为结束符的,所以存放结果为
             \0987\0987654321
             因为s指向的位置为5,d指向的位置为1;

 如果改为memcpy,如memcpy(d,s,4);则执行后的栈布局为
            栈底-------------------------->栈顶
     \09876543214321
 所以结果为d="1234123456789"
而s头指针不变,s="123456789"

            

相关文章推荐

字符处理函数

  • 2011年12月08日 23:12
  • 51KB
  • 下载

C语言的字符处理函数库

C语言的字符处理函数库提供了两类函数,一类是字符测试函数,一类是字符大小写转换函数。尽管可以使用其他方式来实现这些功能,但建议使用这些库函数,因为这些函数有以下优点:大多数由宏实现,在运行速度上进行了...

C Language Study - 三大字符处理函数实现

三大字符处理函数实现|||| ==--==--==--==--==--==-- strlen , strcpy, strcmp.

ctype.h字符处理函数

ctype.h里的函数   1 字符测试函数   1> 函数原型均为int isxxxx(int)   2> 参数为int, 任何实参均被提升成整型   3> 只能正确处理处于[0, 127]...
  • zhymxt
  • zhymxt
  • 2012年06月16日 21:36
  • 422

PHP详解ASCII码对照表与字符转换 && 字符串处理函数库

" (转自:http://home.phpchina.com/blog-83109-193258.html) PHP基础篇详解ASCII码对照表与字符转换,讨论ASCII码对照表图与字...

宽字符和普通字符串处理函数详细介绍

字符分类:     宽字符函数普通C函数描述  iswalnum()     isalnum() 测试字符是否为数字或字母  iswalpha()     isalpha() 测试字符是否是字母 ...

自定义字符数组处理函数:strlen,strcmp,strcat,strcpy

C/C++中提供了众多的字符串处理函数,在面试中偶尔会遇到要求手写这些函数,下面我们给出strlen,strcmp,strcat,strcpy这四个函数的参考代码。使用这些函数时,参数必须是以null...

C/C++的字符处理函数很重要

C/C++的字符处理函数很重要,罗列如下: 一、.字符处理库中的函数 头文件是ctype.h或cctype 函数原型:int f(int c) f可为如下几种: is...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:字符处理函数的区别
举报原因:
原因补充:

(最多只允许输入30个字)