詳解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()的感化沒有甚麼兩樣。