1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > java strcpy 详解C语言中strcpy()函数与strncpy()函数的使用

java strcpy 详解C语言中strcpy()函数与strncpy()函数的使用

时间:2020-06-03 18:53:49

相关推荐

java strcpy 详解C语言中strcpy()函数与strncpy()函数的使用

C语言strcpy()函数:复制字符串

头文件:#include

定义函数:

char *strcpy(char *dest, const char *src);

函数说明:strcpy()会将参数src 字符串拷贝至参数dest 所指的地址。

返回值:返回参数dest 的字符串起始地址。

附加说明:如果参数 dest 所指的内存空间不够大,可能会造成缓冲溢出(buffer Overflow)的错误情况,在编写程序时请特别留意,或者用strncpy()来取代。

范例

#include

main(){

char a[30] = "string(1)";

char b[] = "string(2)";

printf("before strcpy() :%s\n", a);

printf("after strcpy() :%s\n", strcpy(a, b));

}

执行结果:

before strcpy() :string(1)

after strcpy() :string(2)

C语言strncpy()函数:复制字符串的前n个字符

头文件:#include

strncpy()用来复制字符串的前n个字符,其原型为:

char * strncpy(char *dest, const char *src, size_t n);

【参数说明】dest 为目标字符串指针,src 为源字符串指针。

strncpy()会将字符串src前n个字符拷贝到字符串dest。

不像strcpy(),strncpy()不会向dest追加结束标记'\0',这就引发了很多不合常理的问题,将在下面的示例中说明。

注意:src 和 dest 所指的内存区域不能重叠,且 dest 必须有足够的空间放置n个字符。

【返回值】返回字符串dest。

【函数示例】拷贝4组字符串。

#include

#include

int main(void){

char dest1[20];

char src1[] = "abc";

int n1 = 3;

char dest2[20]="********************";

char src2[] = "abcxyz";

int n2 = strlen(src2)+1;

char dest3[100] = "http://see./cpp/shell/";

char src3[6] = "abcxyz"; // 没有'\0'

int n3 = 20;

char dest4[100] = "http://see./cpp/u/yuanma/";

char src4[] = "abc\0defghigk";

int n4 = strlen(src3);

strncpy(dest1, src1, n1); // n1小于strlen(str1)+1,不会追加'\0'

strncpy(dest2, src2, n2); // n2等于strlen(str2)+1,恰好可以把src2末尾的'\0'拷贝到dest2

strncpy(dest3, src3, n3); // n3大于strlen(str3)+1,循环拷贝str3

strncpy(dest4, src4, n4); // src4中间出现'\0'

printf("dest1=%s\n", dest1);

printf("dest2=%s, dest2[15]=%c\n", dest2, dest2[10]);

printf("dest3=%s\n", dest3);

printf("dest4=%s, dest4[6]=%d, dest4[20]=%d, dest4[90]=%d\n", dest4, dest4[6], dest4[20], dest4[90]);

return 0;

}

VC6.0运行结果:

MinGW运行结果:

从上面的运行结果可以看出,strncpy()很难掌控,行为诡异。使用strncpy()最安全方式是使n等于strlen(src)+1,即拷贝整个字符串,同时将'\0'追加到dest。但这又与strcmp()的作用没有什么两样。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。