C語言 模擬實現(xiàn)strcpy與strcat函數(shù)詳解
這里有超詳細的函數(shù)模實現(xiàn)分享,帶大家一起來模擬實現(xiàn)這些函數(shù),后續(xù)還將更新更多的函數(shù)模擬實現(xiàn)的文章。
一、strcpy函數(shù)的介紹
1.函數(shù)的聲明
char* strcpy(char * destination, const char * source );
2.函數(shù)功能與注意事項
- 將源指向的字符串復(fù)制到目標(biāo)指向的數(shù)組中,包括終止空字符(并在該點停止)。
- 源字符串必須以 '\0' 結(jié)束。
- 會將源字符串中的 '\0' 拷貝到目標(biāo)空間。
- 目標(biāo)空間必須足夠大,以確保能存放源字符串。
- 目標(biāo)空間必須可變。
3.函數(shù)的使用
#include<stdio.h>
#include<string.h>//使用strcpy函數(shù)時記得引用它的頭文件
int main()
{
char ch1[7] = "abcdef";
char ch2[10];//ch2為目標(biāo)數(shù)組,空間必須比ch1大
strcpy(ch2, ch1);
printf("%s\n", ch2);
return 0;
}運行結(jié)果

二、模擬實現(xiàn)strcpy函數(shù)
1.模擬分析
1.我們需要將源指向的字符串復(fù)制到目標(biāo)指向的數(shù)組中,包括終止空字符,所以我們就可以一個字符一個字符的復(fù)制過去,注意終止空字符'\0'也要復(fù)制過去,如果沒有將‘\0’復(fù)制過去的話,后面如果想要打印將這個賦值過去的字符串的話就會出現(xiàn)問題。
2.因為我們源指向的字符串是不需要改變的,所以我們需要將我們源指向的字符串用const限制,以防它被改變,讓其變得更安全。
3.為了避免傳進來的地址是空指針,我們需要用assert來斷言傳進來的地址不是空指針。
4.為了實現(xiàn)鏈?zhǔn)皆L問,我們要將傳進來的目標(biāo)起始地址(destination)返回。由于這個函數(shù)在執(zhí)行的時候會改變destination存儲的內(nèi)容,所以我們要重新創(chuàng)建一個char*類型的指針來存儲這個地址。
2.模擬實現(xiàn)
下面代碼有點干,需要細品,建議收藏以免忘記。
#include<stdio.h>
#include<assert.h>
char* my_strcpy(char* dest, const char* src)
{
assert(dest && src);
char* ret = dest;
while (*dest++ = *src++)
{
;
}
return ret;
}
int main()
{
char ch1[7] = "abcdef";
char ch2[10];//ch2為目標(biāo)數(shù)組,空間必須比ch1大
my_strcpy(ch2, ch1);//將ch1中的字符串復(fù)制到ch2中
printf("%s\n", my_strcpy(ch2, ch1));//鏈?zhǔn)皆L問
return 0;
}運行結(jié)果

三、strcat函數(shù)的介紹
1.函數(shù)的聲明
char * strcat ( char * destination, const char * source );
2.函數(shù)功能與注意事項
- 將源字符串追加到目標(biāo)字符串。目標(biāo)字符串的終止空字符'\0'被源字符串的第一個字符覆蓋,并包含一個終止空字符'\0'在新字符串的末尾,由兩者在目的地連接而成。
- 源字符串必須以 '\0' 結(jié)束。
- 目標(biāo)空間必須有足夠的大,能容納下源字符串的內(nèi)容。
- 目標(biāo)空間必須可修改。
3.函數(shù)的使用
#include<stdio.h>
#include<string.h>//使用strcat函數(shù)時記得引用它的頭文件
int main()
{
char ch1[4] = "def";
char ch2[7] = "abc"; //ch2為目標(biāo)數(shù)組,空間必須比ch1大
strcat(ch2, ch1); //將ch1中的字符串追加到ch2中
printf("%s", ch2);
return 0;
}運行結(jié)果

四、模擬實現(xiàn)strcat函數(shù)
1.模擬分析
1.我們追加字符串時是將源字符串追加到目標(biāo)字符串里面,我們需要將從目標(biāo)字符串里面'\0'的位置開始追加,所以我們首先就需要找到目標(biāo)字符串中'\0'的位置。并且我們追加完后需要在字符串的追后多追加一個'\0',使這個新字符串完整。
2.因為我們源指向的字符串是不需要改變的,所以我們需要將我們源指向的字符串用const限制,以防它被改變,讓其變得更安全。
3.為了避免傳進來的地址是空指針,我們需要用assert來斷言傳進來的地址不是空指針。
4.為了實現(xiàn)鏈?zhǔn)皆L問,我們要將傳進來的目標(biāo)起始地址(destination)返回。由于這個函數(shù)在執(zhí)行的時候會改變destination存儲的內(nèi)容,所以我們要重新創(chuàng)建一個char*類型的指針來存儲這個地址。
2.模擬實現(xiàn)
#include<stdio.h>
#include<assert.h>
char* my_strcat(char* dest, const char* src)
{
assert(dest && src);//斷言傳進來的地址不是空指針
char* ret = dest;//保存目標(biāo)起始地址
while (*dest)//找到'\0'的地址
{
dest++;
}
while (*dest++ = *src++)//追加字符串
{
;
}
return ret;
}
int main()
{
char ch1[4] = "def";
char ch2[7] = "abc"; //ch2為目標(biāo)數(shù)組,空間必須比ch1大
printf("%s\n", my_strcat(ch2, ch1));//鏈?zhǔn)皆L問
return 0;
}運行結(jié)果

總結(jié)
這就是今天的全部內(nèi)容了,要是大家覺得有用的話記得給博主一個三連哦,嘻嘻。最后??佳械耐瑢W(xué)都能上岸,找工作的同學(xué)都能進大廠。
到此這篇關(guān)于C語言 模擬實現(xiàn)strcpy與strcat函數(shù)詳解的文章就介紹到這了,更多相關(guān)C語言 strcpy函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- C語言中strcpy和strcat的使用和模擬實現(xiàn)
- C語言string庫strcpy、strcmp、strcat函數(shù)的使用
- 利用C語言模擬實現(xiàn)qsort,strcpy,strcat,strcmp函數(shù)
- C語言strlen,strcpy,strcmp,strcat,strstr字符串操作函數(shù)實現(xiàn)
- C語言詳細講解strcpy strcat strcmp函數(shù)的模擬實現(xiàn)
- 徹底掌握C語言strcat函數(shù)的用法
- C語言字符串函數(shù)操作(strlen,strcpy,strcat,strcmp)詳解
- strcat 函數(shù)的使用指南
- strcat函數(shù)實現(xiàn)簡單示例
- c++實現(xiàn)strcat字符串連接庫函數(shù)的方法詳解
- c++ 連接兩個字符串實現(xiàn)代碼 實現(xiàn)類似strcat功能
- C語言strcat函數(shù)詳解:字符串追加的利器
相關(guān)文章
C語言詳細講解strcpy strcat strcmp函數(shù)的模擬實現(xiàn)
這篇文章主要介紹了怎樣用C語言模擬實現(xiàn)strcpy與strcat和strcmp函數(shù),strcpy()函數(shù)是C語言中的一個復(fù)制字符串的庫函數(shù),strcat()函數(shù)的功能是實現(xiàn)字符串的拼接,strcmp()函數(shù)作用是比較字符串str1和str2是否相同2022-05-05
C++ virtual destructor虛擬析構(gòu)函數(shù)
C++中基類采用virtual虛析構(gòu)函數(shù)是為了防止內(nèi)存泄漏。具體地說,如果派生類中申請了內(nèi)存空間,并在其析構(gòu)函數(shù)中對這些內(nèi)存空間進行釋放,今天通過本文給大家介紹C++ virtual destructor虛擬析構(gòu)函數(shù)的相關(guān)知識,感興趣的朋友一起看看吧2021-05-05
C++實現(xiàn)將內(nèi)容寫入文件的方法總結(jié)
本文主要總結(jié)了一下C/C++將內(nèi)容寫入文件的方法,C的方法有些單調(diào),畢竟沒有庫函數(shù)。C++則豐富些,下面我把搜集到的整理一下,供大家參考2023-04-04
GCC編譯過程(預(yù)處理,編譯,匯編,鏈接)及GCC命令詳解
文章詳細介紹了GCC編譯器的工作原理,包括預(yù)處理、編譯、匯編和鏈接四個主要階段,每個階段都有其特定的任務(wù)和輸出文件,文章還解釋了如何使用GCC命令選項來查看每個階段的輸出,以及如何通過調(diào)整編譯選項來優(yōu)化程序性能或調(diào)試問題,感興趣的朋友跟隨小編一起看看吧2024-11-11

