C++中strlen函數(shù)的三種實現(xiàn)方法
一、strlen函數(shù)是什么
我們經常用到strlen這個函數(shù)求字符串長度,但是它是怎么實現(xiàn)的呢?接下來讓給我用三種方法帶你們看看它是如何實現(xiàn)?
首先我們先來了解一下strlen這個函數(shù),strlen 是求字符串長度的函數(shù),它的返回值是size_t,就是unsigned int。字符串以'\0'作為結束標志,strlen函數(shù)返回的值就是在字符串中'\0'的前面出現(xiàn)的個數(shù)(不包含'\0')。所以我們在想strlen 是怎么實現(xiàn)的就可以從這里入手,從第一個字符開始找起,找到'\0'結束,計算個數(shù)。
二、strlen的三種實現(xiàn)方法
1、第一種方法(直接)
size_t my_strlen( const char* str)//字符串是放在常量字符串中,不能被改變,所以這里最好用用const修飾一下下啦
{
assert(str != NULL);//p如果接收過來的是空指針,那么這里運行會崩潰的,所以這里用assert函數(shù)斷言一下
int count = 0;//計數(shù)
while (*str != '\0')
{
count++;//當它的字符不等于'\0'時,計數(shù)加一
str++;//再往下一個字符找
}
return count;
}2、第二種方法(遞歸)
size_t my_strlen(const char* str)//字符串是放在常量字符串中,不能被改變,所以這里最好用用const修飾一下下啦
{
assert(str != NULL);//p如果接收過來的是空指針,那么這里運行會崩潰的,所以這里用assert函數(shù)診斷一下
if (*str != '\0')
{
return 1+my_strlen(str+1);
}
else
{
return 0;
}
}return 1+my_strlen(str+1);//這里意思是說當首字符不等于'\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如果接收過來的是空指針,那么這里運行會崩潰的,所以這里用assert函數(shù)診斷一下
const char* start = str;//定義一個指針放字符串首字符的地址,因為*str接收的字符串為常量字符串,所以這里最好也用const修飾一下
while (*str != '\0')
{
str++;
}
return str - start;
}四、小結
以上就是strlen 函數(shù)的三種實現(xiàn)方法,我平常在用這個函數(shù)時可能很少會去關心它是怎么實現(xiàn)的,直接用就完了,但是了解一個函數(shù)是怎么實現(xiàn)的對于理解是有好處的。
到此這篇關于C++中strlen函數(shù)的三種實現(xiàn)方法的文章就介紹到這了,更多相關C++ strlen內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
C/C++使用socket實現(xiàn)判斷ip是否能連通
這篇文章主要為大家詳細介紹了C/C++如何使用socket實現(xiàn)判斷ip是否能連通,文中的示例代碼講解詳細,具有一定的學習價值,感興趣的小伙伴可以了解一下2023-07-07
C++結合OpenCV實現(xiàn)RRT算法(路徑規(guī)劃算法)
這篇文章主要介紹了C++結合OpenCV實現(xiàn)RRT算法,RRT算法整體框架主要分為rand、near、new三點的建立和near與new之間的安全性檢查,需要的朋友可以參考下2022-05-05
SublimeText編譯C開發(fā)環(huán)境設置
這篇文章主要介紹了使用SublimeText編譯C代碼的開發(fā)環(huán)境設置,大家參考使用2013-11-11

