C語(yǔ)言多種獲取字符串長(zhǎng)度的方法
在C語(yǔ)言中,想要獲取字符串長(zhǎng)度可以有很多方法,下面分別介紹
一、使用sizeof()運(yùn)算符
在C語(yǔ)言中,sizeof() 是長(zhǎng)度的運(yùn)算符,括號(hào)中可以放入數(shù)據(jù)類型或者表達(dá)式,一般我們用來(lái)計(jì)算字符串長(zhǎng)度。
基本用法:
int i=10; sizeof(i);//表達(dá)式 char str[]="hello world"; sizeof(str); sizeof(double);//數(shù)據(jù)類型
在使用sizeof()求字符串長(zhǎng)度時(shí),會(huì)將 ‘\0' 也計(jì)算到字符串長(zhǎng)度中。例如"abcd"用sizeof()求長(zhǎng)度會(huì)計(jì)算得到5。
注意:char str[100]=""; sizeof(str)的值是100。
二、使用strlen函數(shù)
在string.h中提供了計(jì)算字符串長(zhǎng)度的函數(shù)。
語(yǔ)法:
size_t strlen(const char *str);
在使用strlen函數(shù)時(shí),需要添加string.h頭文件,該函數(shù)會(huì)將字符串長(zhǎng)度計(jì)算出,不包含 ‘\0'。
三、編寫函數(shù)
如果不想使用sizeof()和strlen(),可以利用循環(huán)來(lái)判斷字符串的長(zhǎng)度。
int get_length(char str[])
{
char *p = str;
int count = 0;
while (*p++ != '\0')
{
count++;
}
return count;
}
該函數(shù)通過(guò)傳入一個(gè)字符串,返回一個(gè)長(zhǎng)度數(shù)值。
測(cè)試代碼:
#include <stdio.h>
#include <string.h>
int get_length(char str[])
{
char *p = str;
int count = 0;
while (*p++ != '\0')
{
count++;
}
return count;
}
int main()
{
char str[] = "abcd";
int count1 = sizeof(str);
int count2 = strlen(str);
int count3 = get_length(str);
printf("use sizeof the length is %d\n", count1);
printf("use strlen the length is %d\n", count2);
printf("use get_length the length is %d\n", count3);
return 0;
}
結(jié)果:

到此這篇關(guān)于C語(yǔ)言多種獲取字符串長(zhǎng)度的方法的文章就介紹到這了,更多相關(guān)C語(yǔ)言獲取字符串長(zhǎng)度內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于vector迭代器失效的幾種情況總結(jié)
下面小編就為大家?guī)?lái)一篇關(guān)于vector迭代器失效的幾種情況總結(jié)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-12-12
C++實(shí)現(xiàn)LeetCode(186.翻轉(zhuǎn)字符串中的單詞之二)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(186.翻轉(zhuǎn)字符串中的單詞之二),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
C++中的動(dòng)態(tài)規(guī)劃子序列問(wèn)題分析探討
可能有些讀者有接觸過(guò)動(dòng)態(tài)規(guī)劃,可能也有一些讀者以前完全不知道動(dòng)態(tài)規(guī)劃這個(gè)東西,別擔(dān)心,我這篇文章會(huì)為讀者做一個(gè)入門,好讓讀者掌握這個(gè)重要的知識(shí)點(diǎn)2023-03-03
C++ 冒泡排序數(shù)據(jù)結(jié)構(gòu)、算法及改進(jìn)算法
冒泡排序是一種簡(jiǎn)單排序。這種排序是采用“冒泡策略”將最大元素移到最右邊。在冒泡過(guò)程中,相鄰兩個(gè)元素比較,如果左邊大于右邊的,則進(jìn)行交換兩個(gè)元素。這樣一次冒泡后,可確保最大的在最右邊。然后執(zhí)行n次冒泡后排序即可完畢2013-04-04
c++打印封裝每次打印前面加上時(shí)間戳問(wèn)題
這篇文章主要介紹了c++打印封裝每次打印前面加上時(shí)間戳問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
C++ 將字符串值賦給CHAR數(shù)組的實(shí)現(xiàn)
這篇文章主要介紹了C++ 將字符串值賦給CHAR數(shù)組的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01
c語(yǔ)言conio.h基本知識(shí)點(diǎn)總結(jié)
在本篇文章里小編給大家分享的是關(guān)于c語(yǔ)言conio.h是什么意思的相關(guān)知識(shí)點(diǎn),需要的朋友們可以學(xué)習(xí)參考下。2020-02-02

