我們都知道 strcpy() 函數是字符串拷貝函數,那麼我們怎樣來模擬實現這個函數呢?!
首先,我們要明白,strcpy() 在拷貝字符串的時候是一個一個拷貝的,直到遇到字符串結束標誌 '\0' 時才停止拷貝。所以,明白了這一點,我們就可一進行簡單的模擬實現了
#include<stdio.h> #include<stdlib.h> #include<assert.h> char *my_strcpy(char *str1, const char *str2) { assert(str1); assert(str2); while(*str1 != '\0') //目標地址遇到'\0'結束 { *str1 = *str2; str1++; str2++; } //while(*str2 != '\0') //注意判斷條件一定不能這樣寫 //{ // *str1 = *str2; // str1++; // str2++; //} return str1; } int main() { char str[10]; //目標地址一定要是一個字符數組 char *pa = "abcdef"; my_strcpy(str,pa); printf("%s\n",str); system("pause"); return 0; }
由於目標地址是沒有初始化的一個字符數組,它裏邊存的內容我們是不知道的,並且在拷貝的過程中它會連同 *pa 中的 '\0' 一塊拷貝,所以 while 條件句中的判斷是 *str1 != '\0' ,如果判斷錯誤即寫爲 *str2 != '\0' ,那麼就會得到以下結果。
關於 my_strcpy() 函數模擬實現的幾點要求:
1.拷貝時是連同字符串中的 '\0' 一塊拷貝的;
2.函數實參的設定:原字符串前要加 const 保護;
3.函數的返回值類型要是 char* 類型(便於鏈式訪問);
4.進入函數內部,要對兩個指針進行斷言,判斷指針是否爲空;
5.函數要返回一個值(地址);
6.一定要進行優化
最優化代碼:
char *my_strcpy(char *str1, const char *str2) { assert(str1); assert(str2); while(*str1++ = *str2++) { ; } return str1; }