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()的作用沒有什么兩樣。
新聞熱點
疑難解答
圖片精選