C語言strlen函數(shù)全方位講解
strlen函數(shù)的講解
strlen函數(shù)我們應(yīng)該不陌生,它可以幫助我們求字符串的長度(不包括’\0’),但里面還有一些細節(jié)需要我們注意??匆幌孪旅孢@張圖:

strlen函數(shù)的頭文件是<string.h>.如果要使用strlen這個函數(shù),別忘記引頭文件。
字符串是以 ‘\0’ 作為結(jié)束標志,strlen函數(shù)返回的是在字符串中 ‘\0’ 前面出現(xiàn)的字符個數(shù)。以下是用strlen函數(shù)時可能會遇到的幾種問題,先看代碼:
#include<stdio.h>
#include<string.h>
int main()
{
char arr1[] = "qwer";
char arr2[] = { 'q','w','e','r' };
char arr3[] = { 'q','w','e','r','\0'};
char arr4[10]= { 'q','w','e','r' };
printf("arr1:%d\n", strlen(arr1));
printf("arr2:%d\n", strlen(arr2));
printf("arr2:%d\n", strlen(arr3));
printf("arr2:%d\n", strlen(arr4));
return 0;
}
以上代碼輸出的結(jié)果是什么?大家可以先試著算一下。然后再看運行結(jié)果。

運行結(jié)果如圖所示,arr1初始化的時候存放的是字符串,字符串的是以’\0’ 為結(jié)束標志的,所以arr1的大小為4。這個應(yīng)該問題不大。
重點說一下下面這幾個。
arr2:我在初始化arr2的時候,是對arr2是以字符進行初始化的,但是我沒有設(shè)置arr的大小,所以編譯器是不知道arr2的大小的,后面存放的是什么東西也是不知道的,但是strlen它是找’\0’的,并返回’\0’之前字符的個數(shù)。所以
在strlen找到’\0’之前,前面有36個字符。
arr3:arr3與arr2不同的是,但是我在最后輸入了’\0’進行初始化,所以arr3很簡單的就找到了’\0’,并返回4。
arr4:arr4與arr2不同的是:我這次設(shè)置了arr4的大小,然后我用字符對arr4進行了初始化,雖然是用字符進行的部分初始化,但是編譯器會幫我把沒初始化的地方默認初始化為0,‘\0’的ASCII碼值就是0,C語言字符在內(nèi)存的形式就是ASCII碼值,所以后面沒初始化的地方存放的都是’\0’。
我們再來看一個東西,由上面的圖,我們還可以知道strlen的返回值是size_t,這是一個無符號數(shù)。如果不清楚這個地方,我們也可能會在使用strlen的時候出現(xiàn)一些問題??匆幌孪旅娴拇a:
#include<stdio.h>
#include<string.h>
int main()
{
if (strlen("abc") - strlen("qwer") < 0)
{
printf("1");
}
else
{
printf("0");
}
return 0;
}
對于上面的代碼的運行結(jié)果是什么?
按常理來說,前面的字符串大小為3,后面的為4,比4小應(yīng)該會打印1。我們來看運行結(jié)果:

它的運行結(jié)果是0,難道前面的字符串大小比后面的大嗎,其實不是。關(guān)鍵在于它的返回值是一個無符號數(shù)。無符號數(shù)只有正數(shù),沒有負數(shù)。3-4=-1,但是此時的-1并不是有符號數(shù),而是一個無符號數(shù),那么-1此時就是一個很大的正數(shù)。所以此時才會輸出0
如果要解決這個問題,有以下兩種解決方案:
方法1:不相減,進行比較:
#include<stdio.h>
#include<string.h>
int main()
{
if (strlen("abc") < strlen("qwer"))
{
printf("1");
}
else
{
printf("0");
}
return 0;
}
方法2:強制類型轉(zhuǎn)換
#include<stdio.h>
#include<string.h>
int main()
{
if ((int)strlen("abc") -(int)strlen("qwer") < 0)
{
printf("1");
}
else
{
printf("0");
}
return 0;
}
說一下方法1,無符號數(shù)只有正數(shù),沒有負數(shù),直接計算大?。ㄕ龜?shù))就可以直接比較了。方法2是強制轉(zhuǎn)換為int類型的數(shù)據(jù),整型是有符號數(shù),有符號數(shù)就可以進行相減,結(jié)果為-1,就是-1。兩種結(jié)果輸出結(jié)果都是1.
strlen函數(shù)的模擬實現(xiàn)
講完了strlen函要注意的問題,下面講一下strlen函數(shù)的模擬實現(xiàn)??偣灿腥N方法:計數(shù)器方式,遞歸的方式和指針-指針的方式。
計數(shù)器方式
實現(xiàn)的思想:設(shè)置一個計數(shù)的變量,讓一個字符指針遍歷字符數(shù)組的每一個元素,如果指針指向的元素不是’\0’,計算器就自增,直到指針指向的元素是’\0’,就停止遍歷,并返回計數(shù)器。
因為是模擬實現(xiàn),我們就只求一致,返回值就設(shè)置為size_t。
實現(xiàn)代碼如下:
#include<stdio.h>
#include<string.h>
#include<assert.h>
size_t my_strlen(const char* p)
{
int count = 0;
assert(p != NULL);//如果等于空指針就會報錯
while((*p) != '\0')
{
count++;
p++;
}
return count;
}
int main()
{
char arr[] = "CSDN";
int ret = my_strlen(arr);
printf("%d", ret);
return 0;
}遞歸的方式
代碼實現(xiàn)的思想:這種方式是不用創(chuàng)建臨時變量的一種方法, 只使用指針進行遍歷,如果指針指向的不是’\0’,那么就返回1和指針指向后一個數(shù)據(jù)的結(jié)果。
size_t my_strlen(const char* p)
{
if ((*p) == '\0')
{
return 0;
}
else
{
return 1 + my_strlen(p+1);
}
}
int main()
{
char arr[] = "CSDN";
int ret = my_strlen(arr);
printf("%d", ret);
return 0;
}
指針減指針的方式
代碼實現(xiàn)的思想:
元素名是首元素的地址,我們就在定義一個指針,指向這個數(shù)組,讓這個指針進行遍歷,指向的不是’\0’就讓指針進行自增。最后讓遍歷完數(shù)組的指針減去數(shù)組名(也就是首元素的地址)。
注意:當兩個指著指向同一塊空間時,指針減指針的絕對值就是兩個指針之間的元素個數(shù),而不是 個數(shù)*數(shù)據(jù)類型所占的空間。
size_t my_strlen(const char* p)
{
char* s = p;
while((*s) != '\0')
{
s++;
}
return s - p;
}
int main()
{
char arr[] = "CSDN";
int ret = my_strlen(arr);
printf("%d", ret);
return 0;
}
到此這篇關(guān)于C語言strlen函數(shù)全方位講解的文章就介紹到這了,更多相關(guān)C語言strlen函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C/C++編程判斷String字符串是否包含某個字符串實現(xiàn)示例
這篇文章主要為大家介紹了C++編程中判斷String字符串是否包含某個字符串的實現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-11-11
淺析string 與char* char[]之間的轉(zhuǎn)換
與char*不同的是,string不一定以NULL('\0')結(jié)束。string長度可以根據(jù)length()得到,string可以根據(jù)下標訪問。所以,不能將string直接賦值給char*2013-10-10
C/C++中一次性執(zhí)行多個DOS命令的實現(xiàn)思路
在C語言中執(zhí)行DOS命令的方法很多,在這就不一給大家一一介紹了,本文重點給大家介紹C/C++中一次性執(zhí)行多個DOS命令的實現(xiàn)思路,需要的朋友參考下2017-12-12
關(guān)于數(shù)據(jù)結(jié)構(gòu)單向鏈表的各種操作
這篇文章主要介紹了關(guān)于數(shù)據(jù)結(jié)構(gòu)單向鏈表的各種操作,關(guān)于數(shù)據(jù)結(jié)構(gòu)鏈表的操作一般涉及的就是增刪改查,下面將關(guān)于無空頭鏈表展開介紹,需要的朋友可以參考下2023-04-04

