一篇文章教你如何用C語言實(shí)現(xiàn)strcpy和strlen
自己實(shí)現(xiàn)strcpy、strlen
strcpy的實(shí)現(xiàn)
思路:
通過指針訪問地址然后將要copy的文本逐一復(fù)制到目的地。
void my_strcpy(char* dest, char* src){ while (*src !='\0'){ *dest = *src; src++; dest++; } *dest = *src; } //自己實(shí)現(xiàn)strcpy int main(){ char arr1[]="$$$$$$$$$$"; char arr2[]="hello"; my_strcpy(arr1,arr2);//將arr的內(nèi)容復(fù)制到arr1中 printf("%s\n",arr2); return 0; }
優(yōu)化1:
在my_strcpy()函數(shù)中*dest和*src直接在表達(dá)式中自加,先試用后加所以使用后置++
void my_strcpy(char* dest, char* src){ while (*src !='\0'){ *dest++ = *src++; } *dest = *src; }
優(yōu)化2:
在while循環(huán)中,因?yàn)樽詈蟮慕K止條件是賦值到了絕對0的時候停止循環(huán)。那么最后一次賦值就是賦值0。那我們直接可以將賦值作為我們的終止條件。
void my_strcpy(char* dest, char* src){ while (*dest++ = *src++); *dest = *src; }
優(yōu)化3:
如果傳入的是空指針我們應(yīng)該告訴這個輸入有問題。
引入assert();斷言–>如果輸入錯誤顯示錯誤。 個人理解就像java,python中的異常處理。
#include <assert.h> void my_strcpy(char* dest, char* src){ assert(dest != NULL); assert(src != NULL); while (*dest++ = *src++); *dest = *src; } //自己實(shí)現(xiàn)strcpy int main(){ char arr1[]="$$$$$$$$$$"; char arr2[]="hello"; my_strcpy(arr1,NULL);//將arr的內(nèi)容復(fù)制到arr1中 printf("%s\n",arr2); return 0; }
優(yōu)化4:
在程序員將dest 和 src寫反的情況。我們應(yīng)該怎么處理呢?
加const 使得我們的原來的數(shù)據(jù)不能被拷貝數(shù)據(jù)不能進(jìn)行修改。從強(qiáng)制檢測。另一方面解釋:源頭的數(shù)據(jù)的安全性得到保證。
#include <assert.h> void my_strcpy(char* dest,const char* src){ assert(dest != NULL); assert(src != NULL); while (*dest++ = *src++); //這里寫反的話將不能進(jìn)行賦值 因?yàn)閏 *dest = *src; }
對于const的講解
const int* p = # int* const p = # const int* const p = #
在第一行中:即const 放在指針變量* 的左邊的時候修飾的是*p 也就是說也就是說不能通過*p來改變*p(num )的值。
在第二行中:即const放在指針變量* 的右邊的時候修飾的是指針本身p,p不能被改變。
在第三行中:兩邊都進(jìn)行const修飾,p與*p都不能改變了。
我的理解:const只能修飾關(guān)鍵字本身右邊的第一個東西(像int*就直接理解為指針)。const修飾的東西被限制。
優(yōu)化5:
在官方提供的庫函數(shù)中strcpy是有返回值的。返回什么呢?我們應(yīng)該返回copy執(zhí)行完成之后的字符串中首字母的地址。但是我們發(fā)現(xiàn)之前已經(jīng)在執(zhí)行的過程中就將dest值修改了。又怎么辦呢?在刷算法題的時候有個經(jīng)驗(yàn)就是,在對地址進(jìn)行操作之前先提前備份一份。然后將備份的這個地址位置返回即可。
#include <assert.h> char* my_strcpy(char* dest,const char* src){ char* res = dest; assert(dest != NULL); assert(src != NULL); while (*dest++ = *src++); *dest = *src;//將'\0'進(jìn)行賦值。 return res; } #include <assert.h> char* my_strcpy(char* dest,const char* src){ char* res = dest; assert(dest != NULL); assert(src != NULL); while (*dest++ = *src++); *dest = *src;//將'\0'進(jìn)行賦值。 return res; }
總結(jié):
1. 分析參數(shù)的設(shè)計(命名,類型),返回值的情況。 2. 關(guān)于野指針問題,空指針的危害。 3. assert的使用方式和作用 4. 參數(shù)部分使用const,以及const的作用。 5. 注釋的重要性。
strlen的實(shí)現(xiàn)
#include <assert.h> int my_strlen(const char* str){//不希望我的字符串被修改。 int count = 0; assert(str != NULL);//用來保證指針的有效性 while(*str !='\0'){ count++; str++; } return count; } int main(){ char arr[] = "abcdef"; int len = my_strlen(arr); printf("%d\n",len); return 0; }
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
- C語言strlen,strcpy,strcmp,strcat,strstr字符串操作函數(shù)實(shí)現(xiàn)
- C語言之sizeof與strlen的使用及區(qū)別
- C語言數(shù)組長度的計算方法實(shí)例總結(jié)(sizeof與strlen)
- 淺談C語言中的sizeof()和strlen()的區(qū)別
- C語言strlen函數(shù)實(shí)現(xiàn)讀取字符串長度詳解
- C語言sizeof和strlen的指針和數(shù)組面試題詳解
- C語言?模擬實(shí)現(xiàn)strlen函數(shù)詳解
- C語言基礎(chǔ) strlen 函數(shù)
- C語言strlen函數(shù)全方位講解
相關(guān)文章
Linux環(huán)境g++編譯GDAL動態(tài)庫操作方法
下面小編就為大家?guī)硪黄狶inux環(huán)境g++編譯GDAL動態(tài)庫操作方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05C++?IO設(shè)備讀寫功能實(shí)現(xiàn)詳解
C++的文件IO(Input,Output)操作就是指對文件進(jìn)行讀寫(輸入與輸出)的操作。輸入就是從磁盤上的文件中讀取內(nèi)容到內(nèi)存中。輸出就是將內(nèi)存中的數(shù)據(jù)內(nèi)容輸出或者說寫入到磁盤的文件中,這篇文章主要介紹了C++?IO設(shè)備讀寫功能實(shí)現(xiàn)2022-11-11C語言創(chuàng)建鏈表錯誤之通過指針參數(shù)申請動態(tài)內(nèi)存實(shí)例分析
這篇文章主要介紹了C語言創(chuàng)建鏈表錯誤之通過指針參數(shù)申請動態(tài)內(nèi)存,是鏈表創(chuàng)建過程中非常常見的經(jīng)典錯誤。實(shí)例中做了較為詳盡的分析,需要的朋友可以參考下2014-09-09