亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++中的string庫函數(shù)常見函數(shù)的作用和使用方法

 更新時(shí)間:2022年04月24日 10:55:21   作者:C0425xjn_  
這篇文章主要介紹了C++中的string庫函數(shù)常見函數(shù)的作用和使用方法,庫函數(shù)的靈活應(yīng)用是程序員的一大重要技能,本文通過實(shí)例實(shí)例代碼給大家講解的非常詳細(xì),需要的朋友可以參考下

??前言: string庫函數(shù)是什么

今天分享一下這幾天對(duì)string庫函數(shù)的一些認(rèn)識(shí)和理解??。
string,中文就是字符串的意思。顧名思義,也就是說在這個(gè)庫函數(shù)頭文件中的函數(shù),都是用來處理和分析字符串的,對(duì)我們使用及研究字符串具有極大的意義。而在平時(shí),我們對(duì)一些處理字符串的函數(shù)并不頻繁使用,導(dǎo)致當(dāng)我們想要用到它時(shí)卻忘記了使用方法。
接下來,我將舉出string頭文件中幾個(gè)較為常見的函數(shù),總結(jié)他們的用法和記憶方法。

??正文

1.strlen函數(shù)

是什么?

strlen函數(shù)是string頭文件中最常見的一個(gè)函數(shù),用于求字符串的長度。 strlen英文全稱string length,既字符串長度,可以顧名思義地來記憶。

具體用法:

?這是從c++ reference上截取的介紹,strlen函數(shù)的用法就是向其傳入一個(gè)字符串?dāng)?shù)組的首元素地址,其返回值是字符的個(gè)數(shù)。

?演示代碼如下:

#include<string.h>
int main()
{
	char str[] = "abc";
	int len1 = strlen(str);
	int len2 = strlen("abc");
	printf("%d\n%d", len1,len2);

	return 0;
}

!!這里應(yīng)該注意的是,"abc"表示的也是一個(gè)字符串?dāng)?shù)組,其傳給strlen函數(shù)的是首元素地址。

運(yùn)行結(jié)果:

??下面我們?cè)囍\(yùn)行一下這個(gè)代碼:

#include<string.h>
int main()
{
	char str1[] = "abc";
	int len1 = strlen(str1);
	char str2[] = { 'a','b','c'};
	int len2 = strlen(str2);
	printf("%d\n%d", len1,len2);

	return 0;
}

運(yùn)行結(jié)果:

?為什么這里的str2的長度會(huì)是13呢?乍一看不是abc三個(gè)元素,長度為3嗎?

這里需要補(bǔ)充一個(gè)知識(shí)點(diǎn)。在C語言中,系統(tǒng)會(huì)在字符串?dāng)?shù)組最后加上一個(gè)’\0’作為結(jié)束標(biāo)志。而strlen函數(shù)的工作原理就是計(jì)算傳入數(shù)組 (首元素地址指針指向的數(shù)組)在’\0’之前的元素個(gè)數(shù),既該字符串長度。

而該代碼塊中所定義的str數(shù)組并不是一個(gè)字符串?dāng)?shù)組,因此’\0’的位置并不在最后一個(gè)元素后面,而是一個(gè)隨機(jī)的位置,strlen函數(shù)會(huì)一直計(jì)算長度直到遇見’\0’才停止工作并返回結(jié)果。
因此,strlen(str2)會(huì)返回一個(gè)隨機(jī)值,該值不代表該數(shù)組的長度。

通過調(diào)試驗(yàn)證了str1字符串?dāng)?shù)組末端有一個(gè)’\0’而str2沒有。

2.strcpy函數(shù)

是什么?

strcpy,英文全稱copies strcpy,也是一個(gè)string頭文件中較為常見的函數(shù),用于將一個(gè)字符串的內(nèi)容復(fù)制到另一個(gè)數(shù)組中。

具體用法

(再次引用c++ reference中的描述,發(fā)現(xiàn)這種英文的工具網(wǎng)站的描述比中文的清晰地多)

?strcpy的使用方法是向其傳入兩個(gè)指針,前者是目標(biāo)數(shù)組首元素地址指針,后者是原字符串?dāng)?shù)組地址指針,將原字符串?dāng)?shù)組(包括末尾結(jié)束標(biāo)志’\0’)拷貝到目標(biāo)數(shù)組中。若目標(biāo)數(shù)組中本身具有元素,則根據(jù)原字符串?dāng)?shù)組的長度一一覆蓋。(?注意:為了防止數(shù)組溢出,目標(biāo)數(shù)組長度應(yīng)大于原字符串?dāng)?shù)組。)

?演示代碼如下:

#include<string.h>
int main()
{
	char str1[] = "abcdefg";
	char str2[] = "123";
	strcpy(str1, str2);//str2==>str1
	printf("%s", str1);//打印拷貝處理后的str1

	return 0;
}

運(yùn)行結(jié)果:

可見,str2的內(nèi)容完美地拷貝到str1中了。

通過調(diào)試可以發(fā)現(xiàn),str2的內(nèi)容覆蓋了str1前四個(gè)元素,而后面的元素依然存在。但是因?yàn)閟tr2的’\0’也跟著拷貝過去了,所以在打印的時(shí)候,由于printf格式控制符是%s(既字符串類型),在遇到第一個(gè)’\0’時(shí)則認(rèn)為它是字符串結(jié)束標(biāo)志,結(jié)束打印。因此,打印出來的結(jié)果是字符串"123"。

3.strcmp函數(shù)

是什么?

strcmp函數(shù),英文全稱compares string(字符串比較), 既用于比較兩個(gè)字符串,那么這里是比較字符串的什么呢?這里的比較是這樣的:先比較兩個(gè)字符串的第一個(gè)字符的ASCII碼值(這里視為第一對(duì)字符),(下面的比較均是ASCII碼值的比較)如果第一個(gè)字符串的第一個(gè)字符大于第二個(gè)字符串的第一個(gè)字符,則返回1;反之,則返回-1;若兩個(gè)字符相等,則進(jìn)行下一對(duì)字符的比較,直到出現(xiàn)有一對(duì)字符不同則返回相應(yīng)的值(1或-1)。若兩個(gè)字符串所有的字符都相同,則返回?cái)?shù)字0。

具體用法:

傳入兩個(gè)指針,代表兩個(gè)字符串?dāng)?shù)組的首元素地址。

?演示代碼如下:

#include<string.h>
int main()
{
	char str1[20];
	char str2[20];
	scanf("%s%s", str1, str2);
	int ret=strcmp(str1, str2);
	switch (ret)
	{
	case 0:printf("str1=str2");break;
	case 1:printf("str1>str2");break;
	case -1:printf("str1<str2");break;
	}
	return 0;
}

運(yùn)行結(jié)果:

 

可見,這里的比較和我們所描述的相一致。
?這里應(yīng)該注意,'\0’的ASCII碼是0,它與其他字符都小。

4.strcat函數(shù)

是什么?

(先介紹strcat)

strcat,英文全稱concatenates string(連接字符串),這里很容易理解,strcat函數(shù)就是用于連接兩個(gè)字符串的,那么它是如何連接的呢?接下來我將介紹一下它的具體用法。

具體用法

?如圖所示,使用strcat函數(shù)需向其傳入兩個(gè)指針,前者是目標(biāo)數(shù)組首元素地址指針,后者是原字符串?dāng)?shù)組地址指針(與strcpy類似,只不過這里是將原字符串接到目標(biāo)字符串后面)。傳參成功后,strcat會(huì)將原字符串的第一個(gè)字符覆蓋到目標(biāo)字符串的’\0’位置,后面再接著原字符串剩下的全部字符,直到遇見’\0’后結(jié)束,保證了拼接后的字符串只有一個(gè)結(jié)束標(biāo)志’\0’。

?演示代碼如下:

#include<string.h>
int main()
{
	char str1[5]="ab";
	strcat(str1, "cd");
	printf("%s\n", str1);

	char str2[5] = "ab";
	char str3[3] = "cd";
	strcat(str2, str3);
	printf("%s\n", str2);
	return 0;
}//原字符串可以用字符串?dāng)?shù)組也可以直接用字符串,結(jié)果相同

運(yùn)行結(jié)果:

如果我們想讓拼接后的字符串更長,能不能修改一下原字符串實(shí)現(xiàn)呢?讓我們來試試看??

int main()
{
	char str1[5]="ab";
	strcat(str1, "cde");
	printf("%s\n", str1);
}

運(yùn)行結(jié)果:

運(yùn)行出錯(cuò),引發(fā)了異常,這是為什么呢?

??這里是因?yàn)榘l(fā)生了數(shù)組溢出,由于"cde"字符串加上’\0’有四個(gè)字符,而str1我們規(guī)定了長度為5,當(dāng)"cde"拼接在str1后覆蓋了它的’\0’之后,拼接字符串一共有六個(gè)字符,超過了目標(biāo)字符串str1的長度,無法容納拼接后的字符串,所以發(fā)生了錯(cuò)誤。
?由此我們可得,在使用strcat函數(shù)時(shí),要規(guī)定給目標(biāo)字符串一個(gè)合適的長度,防止數(shù)組溢出。

5.兩個(gè)不太常用的string頭文件函數(shù)

strstr函數(shù)

strstr,英文全稱Locate substring,既定位子字符串。strstr的返回值比較特殊,它是通過傳入一個(gè)母字符串和一個(gè)子字符串,然后在母字符串中定位子字符串的位置,返回值為指向母字符串中第一次出現(xiàn)的子字符串中指定的整個(gè)字符串的指針。若子字符串不屬于母字符串的一部分,則返回空指針NULL。

?演示代碼如下:

#include<string.h>
int main()
{
	char str1[20]="I love you";
	char* p1 = strstr(str1, "you");
	char* p2 = strstr(str1, "me");
	printf("%s\n%s\n", p1,p2);

}

運(yùn)行結(jié)果:

memset函數(shù)

memset函數(shù),英文全稱Fill block of memory,既填充內(nèi)存塊。memset的作用是將指針指向的內(nèi)存塊(這里可以認(rèn)為是字符串)的第一個(gè)字節(jié)數(shù)設(shè)置為指定的值。

?演示代碼如下:

#include<string.h>
int main()
{
	char str[20]="I love you";
	memset(str, '-', 2);
	printf("%s\n", str);
	return 0;
}

運(yùn)行結(jié)果:

顯而易見,其結(jié)果無非就是將兩個(gè)’-'填充到str字符串的前兩個(gè)位置。

??總結(jié)

????庫函數(shù)的靈活應(yīng)用是程序員的一大重要技能!在總結(jié)這篇文章的時(shí)候我發(fā)現(xiàn)自己的string庫函數(shù)以及其他庫函數(shù)仍有不了解的地方,需要不斷地查資料去了解??偨Y(jié)下來,鞏固了自己對(duì)這部分知識(shí)的掌握,也希望能為您帶來幫助,感謝支持!歡迎大佬雅正。

到此這篇關(guān)于C++中的string庫函數(shù)常見函數(shù)的作用和使用方法的文章就介紹到這了,更多相關(guān)c++ string庫函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Qt實(shí)現(xiàn)棋盤游戲

    Qt實(shí)現(xiàn)棋盤游戲

    這篇文章主要為大家詳細(xì)介紹了Qt實(shí)現(xiàn)棋盤游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • 詳解在C++中顯式默認(rèn)設(shè)置的函數(shù)和已刪除的函數(shù)的方法

    詳解在C++中顯式默認(rèn)設(shè)置的函數(shù)和已刪除的函數(shù)的方法

    這篇文章主要介紹了在C++中顯式默認(rèn)設(shè)置的函數(shù)和已刪除的函數(shù)的方法,文中講到了C++11標(biāo)準(zhǔn)中的新特性,需要的朋友可以參考下
    2016-01-01
  • C語言如何實(shí)現(xiàn)頭插法建立單鏈表

    C語言如何實(shí)現(xiàn)頭插法建立單鏈表

    這篇文章主要介紹了C語言實(shí)現(xiàn)頭插法建立單鏈表的方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • C語言超詳細(xì)講解遞歸算法漢諾塔

    C語言超詳細(xì)講解遞歸算法漢諾塔

    漢諾塔問題是一個(gè)經(jīng)典的問題。漢諾塔(Hanoi Tower),又稱河內(nèi)塔,源于印度一個(gè)古老傳說。本文將用Java求解這一問題,感興趣的可以學(xué)習(xí)一下
    2022-05-05
  • 利用C++實(shí)現(xiàn)一個(gè)線程安全的map

    利用C++實(shí)現(xiàn)一個(gè)線程安全的map

    這篇文章主要為大家詳細(xì)介紹了如何利用C++實(shí)現(xiàn)一個(gè)線程安全的map(使用ChatCPT生成),代碼是通過兩輪對(duì)話完善的,感興趣的小伙伴可以了解一下
    2023-05-05
  • C++11 Unicode編碼轉(zhuǎn)換

    C++11 Unicode編碼轉(zhuǎn)換

    這篇文章主要介紹了C++11 Unicode編碼轉(zhuǎn)換的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)c++11,感興趣的朋友可以了解下
    2020-08-08
  • Qt實(shí)現(xiàn)密碼顯示按鈕

    Qt實(shí)現(xiàn)密碼顯示按鈕

    這篇文章主要為大家詳細(xì)介紹了Qt實(shí)現(xiàn)密碼顯示按鈕,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • C語言與C++中關(guān)于字符串使用的比較

    C語言與C++中關(guān)于字符串使用的比較

    字符串是我們?cè)偈煜げ贿^的東西了,任何語言中字符串都是基礎(chǔ)都要經(jīng)常用到,那么在不同語言中字符串的用法一樣嗎?下面我們來看看C語言與C++中字符串使用的比較
    2022-05-05
  • c/c++ 奇技淫巧(一些c語言的技巧)

    c/c++ 奇技淫巧(一些c語言的技巧)

    這篇文章主要介紹了c/c++ 奇技淫巧,需要的朋友可以參考下
    2017-03-03
  • 淺析C++中的動(dòng)態(tài)內(nèi)存分配

    淺析C++中的動(dòng)態(tài)內(nèi)存分配

    這篇文章主要為大家詳細(xì)介紹了C++中動(dòng)態(tài)內(nèi)存分配的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-03-03

最新評(píng)論