詳解C說話中strcpy()函數與strncpy()函數的應用。本站提示廣大學習愛好者:(詳解C說話中strcpy()函數與strncpy()函數的應用)文章只能為提供參考,不一定能成為您想要的結果。以下是詳解C說話中strcpy()函數與strncpy()函數的應用正文
C說話strcpy()函數:復制字符串
頭文件:#include <string.h>
界說函數:
char *strcpy(char *dest, const char *src);
函數解釋:strcpy()會將參數src 字符串拷貝至參數dest 所指的地址。
前往值:前往參數dest 的字符串肇端地址。
附加解釋:假如參數 dest 所指的內存空間不敷年夜,能夠會形成緩沖溢出(buffer Overflow)的毛病情形,在編寫法式時請特殊留心,或許用strncpy()來代替。
典范
#include <string.h> 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 <string.h>
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<stdio.h> #include<string.h> 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.xidian.edu.cn/cpp/shell/"; char src3[6] = "abcxyz"; // 沒有'\0' int n3 = 20; char dest4[100] = "http://see.xidian.edu.cn/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()的感化沒有甚麼兩樣。