C++中strlen函數(shù)的三種實(shí)現(xiàn)方法
一、strlen函數(shù)是什么
我們經(jīng)常用到strlen這個函數(shù)求字符串長度,但是它是怎么實(shí)現(xiàn)的呢?接下來讓給我用三種方法帶你們看看它是如何實(shí)現(xiàn)?
首先我們先來了解一下strlen這個函數(shù),strlen 是求字符串長度的函數(shù),它的返回值是size_t,就是unsigned int。字符串以'\0'作為結(jié)束標(biāo)志,strlen函數(shù)返回的值就是在字符串中'\0'的前面出現(xiàn)的個數(shù)(不包含'\0')。所以我們在想strlen 是怎么實(shí)現(xiàn)的就可以從這里入手,從第一個字符開始找起,找到'\0'結(jié)束,計(jì)算個數(shù)。
二、strlen的三種實(shí)現(xiàn)方法
1、第一種方法(直接)
size_t my_strlen( const char* str)//字符串是放在常量字符串中,不能被改變,所以這里最好用用const修飾一下下啦 { assert(str != NULL);//p如果接收過來的是空指針,那么這里運(yùn)行會崩潰的,所以這里用assert函數(shù)斷言一下 int count = 0;//計(jì)數(shù) while (*str != '\0') { count++;//當(dāng)它的字符不等于'\0'時,計(jì)數(shù)加一 str++;//再往下一個字符找 } return count; }
2、第二種方法(遞歸)
size_t my_strlen(const char* str)//字符串是放在常量字符串中,不能被改變,所以這里最好用用const修飾一下下啦 { assert(str != NULL);//p如果接收過來的是空指針,那么這里運(yùn)行會崩潰的,所以這里用assert函數(shù)診斷一下 if (*str != '\0') { return 1+my_strlen(str+1); } else { return 0; } }
return 1+my_strlen(str+1);//這里意思是說當(dāng)首字符不等于'\0'說明這個字符串至少有一個字符
舉個例子:
若char[]="abc"
1+my_strlen("bc")
1+1+my_strlen("c")
1+1+1+my_strlen("")--------1+1+1+0(空字符串第一個字符就是'\0')
3、第三種方法(指針-指針)
兩個指針相減,得到的是兩個指針之間元素的個數(shù)。我們先用一個指針放首字符地址,然后再找到最后一個字符的地址,用最后一個字符地址減去第一個字符地址,就是他們之間元素個數(shù)。
size_t my_strlen(const char* str)//字符串是放在常量字符串中,不能被改變,所以這里最好用用const修飾一下下啦 { assert(str != NULL);//p如果接收過來的是空指針,那么這里運(yùn)行會崩潰的,所以這里用assert函數(shù)診斷一下 const char* start = str;//定義一個指針放字符串首字符的地址,因?yàn)?str接收的字符串為常量字符串,所以這里最好也用const修飾一下 while (*str != '\0') { str++; } return str - start; }
四、小結(jié)
以上就是strlen 函數(shù)的三種實(shí)現(xiàn)方法,我平常在用這個函數(shù)時可能很少會去關(guān)心它是怎么實(shí)現(xiàn)的,直接用就完了,但是了解一個函數(shù)是怎么實(shí)現(xiàn)的對于理解是有好處的。
到此這篇關(guān)于C++中strlen函數(shù)的三種實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)C++ strlen內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言 數(shù)據(jù)結(jié)構(gòu)雙向鏈表簡單實(shí)例
這篇文章主要介紹了C語言 數(shù)據(jù)結(jié)構(gòu)雙向鏈表簡單實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-03-03C++學(xué)習(xí)之虛函數(shù)表與多態(tài)詳解
這篇文章主要為大家詳細(xì)介紹了C++中虛函數(shù)表與多態(tài)的相關(guān)知識,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)C++有一定的幫助,感興趣的小伙伴可以了解一下2023-03-03C/C++使用socket實(shí)現(xiàn)判斷ip是否能連通
這篇文章主要為大家詳細(xì)介紹了C/C++如何使用socket實(shí)現(xiàn)判斷ip是否能連通,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價值,感興趣的小伙伴可以了解一下2023-07-07C語言詳細(xì)解析有符號數(shù)與無符號數(shù)的表示
我們知道,在C語言中存在無符號數(shù)和有符號數(shù),但是對于計(jì)算機(jī)而言,其本身并不區(qū)別有符號數(shù)和無符號數(shù),因?yàn)樵谟?jì)算機(jī)里面都是O或者1,但是在我們的實(shí)際使用中有時候需要使用有符號數(shù)來表示一個整數(shù),因此我們規(guī)定,當(dāng)最高位為1的時,表示為負(fù)數(shù),最高位為0時,表示為正數(shù)2022-04-04C++結(jié)合OpenCV實(shí)現(xiàn)RRT算法(路徑規(guī)劃算法)
這篇文章主要介紹了C++結(jié)合OpenCV實(shí)現(xiàn)RRT算法,RRT算法整體框架主要分為rand、near、new三點(diǎn)的建立和near與new之間的安全性檢查,需要的朋友可以參考下2022-05-05SublimeText編譯C開發(fā)環(huán)境設(shè)置
這篇文章主要介紹了使用SublimeText編譯C代碼的開發(fā)環(huán)境設(shè)置,大家參考使用2013-11-11