C++深入講解namespace與string關鍵字的使用
namespace
首先聲明:在C++中支持三種域局部域,名字空間,類域。
1.為什麼使用namespace
在C++中可能會出現這樣的情況:我們正在編寫一個名為myj()函數的代碼,但是另一個可用的庫,它也具有相同的myj()函數。現在編譯器無法知道代碼中使用的myj()函數是哪個版本。
所以namespace就是用來克服這個困難,並被用作額外的信息來區分類似的函數、類、變量等等,它們在不同的庫中具有相同的名稱。使用名稱空間,你可以定義定義名稱的上下文。
本質上,名稱空間定義瞭一個范圍。
2.namespace的定義
- 命名空間將全局作用域分成不同的部分
- 不同命名空間中的標識符可以同名而不會發生沖突
- 命名空間可以發生嵌套
- 全局作用域也叫默認命名空間
舉例說明:
//1.普通的命名空間 namespace myj { int g _max = 10; int g_min = 0; int my_add(int a,int b){ return a+b;} } //2.名字空間域可分層嵌套,同樣有分層屏蔽作用 namespace Primer { double pi = 3.1415926535898; double my_add(double a,double b) {return a + b;} namespace Matrix { char my_max(char a,char b) { return a>b? a:b;} } } //3.同一個工程中允許存在多個相同名稱的命名空間 //編譯器最後會合成同一個命名空間中。 namespace myj { float pi = 3.14; int my_sub(int a,int b) { my_min = a - b; return my_min; } }
3.namespace的使用
- 加名字空間及作用域限定符
- 使用using將名字空間中成員引入
- 使用using namespace名字空間名稱引入
#include <stdio.h> #include <iostream> namespace First { int i = 0; } namespace Second { int i = 1; namespace Internal //嵌套命名空間 { struct P //嵌套命名空間 { int x; int y; }; } } int main() { using namespace First; //使用整個命名空間 using Second::Internal::P; //使用嵌套的命名空間 printf("First::i = %d\n", i); printf("Second::i = %d\n", Second::i); //使用命名空間中的變量 p = { 2, 3 }; printf("p.x = %d\n", p.x); printf("p.y = %d\n", p.y); system("pause"); return 0; }
4.使用using指示符
標準C++庫中的所有組件都是在一個被稱為std的名字空間中聲明和定義的。在采用標準C++的平臺上使用標準C++庫中的組件,隻要寫一個using指示符:
using namespace std;
就可以直接使用標準C++庫中的所有成員。
string
1.string的定義及初始化
定義string的方式跟基本數據類型相同,隻需要在string後跟上變量名
string s;
初始化:
string str = "yyds";
2.訪問string的內容
通過下標訪問,s[i]表示字符串s中下標位i的元素
如果要讀入和輸出整個字符串,則隻能使用cin和cout
如果一定要用printf來輸出string,可以用c_str()函數將string類型轉換為字符數組進行輸出。
printf("%s",str.c_str());
通過迭代器訪問因為string不像其他STL容器那樣需要參數,因此可以直接如下定義:
string::iterator it;
這樣就得到瞭迭代器it,並且可以通過*it來訪問string裡的每一位
3.常用函數
1.operator+
連接兩個字符串或者一個字符串和一個字符。
2.compare operator
兩個string類型可以直接使用==、!=、<、<=、>、>=比較大小,比較規則是字典序。
3.length()/size()兩者返回string的長度,即存放的字符數。
4.insert(pos,string)
在pos號位置插入字符串string
5.insert(it,it2,it3)
it為原字符串的欲插入位置,it2和it3為待插字符串的首位迭代器,用來表示串[it2,it3)將被插在it的位置上。
6.erase()
刪除單個元素,str.erase(it)用於刪除單個元素,it為需要刪除的元素的迭代器。 刪除一個區間內的所有元素。
7.clear()
用以清空string中的數據。
8.substr()
substr(pos,len)返回從pos號位開始、長度為len的字串。
9.string::npos
一個常數,其本身的值為-1,但由於是unsigned_int 類型,因此實際上也可以認為是unsigned_int類型的最大值4294967295。 string::npos用以作為find函數匹配時的返回值。
10.find()
str.find(str2),當str2是str的子串時,返回其在str中第一次出現的位置;如果str2不是str的子串,那麼返回string::npos。 str.find(str2,pos),從str的pos號位開始匹配str2,返回值與上相同。
11.replace()
str.replace(pos,len,str2)把str從pos號位開始、長度為len的子串替換為str2 str.replace(it1,it2,str2)把str的迭代器[it1,it2)范圍的字串替換為str2
12.assign()
str.assign(str.rbegin(),str.rend())可以實現字符串翻轉。
到此這篇關於C++深入講解namespace與string關鍵字的使用的文章就介紹到這瞭,更多相關C++ namespace與string內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!