C++基礎-(模板及標準模板庫)

C++基礎

模板及標準模板庫

  • 模板的作用
    • 模板使程序員能夠快速的建立具有類型安全得庫集合和函數(shù)集合向拆,它的實現(xiàn),方便了大規(guī)模的軟件開發(fā)偏陪。
  • 簡單的求最大值
#include <iostream>
using namespace std;
template <class X>
X Max(X a,X b)
{
    return (a>b?a:b);
}
int main()
{
    int x1=20,x2=100;
    cout<<"max="<<Max<double>(x1,x2)<<endl;
    double y1=22.3,y2=100.2;
    cout<<"max="<<Max<double>(y1,y2)<<endl;
    char z1='A',z2='z';
    cout<<"max="<<Max<char>(z1,z2)<<endl;
}
  • 模板定義
    • 模板的定義很特殊抢呆,由 template<…> 處理的任何東西都意味著編譯器在當時不為它分配存儲空間,它一直處于等待狀態(tài)直到被一個模板實例告知笛谦。所以為了容易使用抱虐,幾乎總是在頭文件中放置全部的模板聲明和定義
#include <iostream>
using namespace std;
template <class X,class Y>
class Test
{
    X m_t1;
    Y m_t2;
    public:
        Test(X t1,Y t2)
        {
            m_t1=t1;
            m_t2=t2;
        }
        void show()
        {
            cout<<"T1="<<m_t1<<"T2="<<m_t2<<endl;
        }
        void print();
};
template <class X,class Y>
void Test<X,Y>::print()
{
    cout<<"t1="<<m_t1<<"t2="<<m_t2<<endl;
}
int main()
{
    Test<int,char> t(10,'s');
    t.show();
    t.print();
}
  • 類模板

    • 使用類模板使用戶可以為類聲明一種模式,使得類中的某些數(shù)據(jù)成員饥脑、某些成員函數(shù)的參數(shù)恳邀、某些成員函數(shù)的返回值懦冰,能取任意類型(包括基本類型的和用戶自定義類型)。
    • 定義
    template <模板參數(shù)表>
    class 類名
    {類成員聲明}
    
    • 在類模板以外定義其成員函數(shù):
    template <模板參數(shù)表>
    類型名 類名<T>::函數(shù)名 ( 參數(shù)表 )
    
  • 類模板與模板類的區(qū)別谣沸。

    • 類模板是模板的定義刷钢,不是一個實實在在的類,定義中用到通用類型參數(shù)乳附。
    • 模板類是實實在在的類定義内地,是類模板的實例化。類定義中參數(shù)被實際類型所代替赋除。
  • 標準模板類

    • 將程序寫的盡可能通用
    • 將算法從特定的數(shù)據(jù)結構中抽象出來阱缓,成為通用的
    • C++的模板為泛型的程序設計奠定了關鍵的基礎
    • STL是泛型程序設計的一個范例
      • 容器(container)
      • 迭代器(itetator)
      • 算法(algorithms)
      • 函數(shù)對象(function object)
  • 容器是容納包含一組元素集合的對象

  • 基本容器

    • 向量(vector)
    • 雙端隊列(deque)
    • 列表(list)
    • 集合(set)
    • 多重集合(multiset)
    • 映射(map)
    • 多重映射(multimap)
  • 容器的接口

    • 通用容器運算符
      • ==,!=举农,>茬祷,>=,<并蝗,<=,=
    • 方法(函數(shù))
      • 迭代方法
        • begin()秸妥,end()滚停,rbegin(),rend()
      • 訪問方法
        • size()粥惧,max_size()键畴,swap(),empty()
  • 順序容器的接口

    • 插入方法
      • push_front()突雪,push_back()起惕,insert(),運算符“=”
    • 刪除方法
      • pop() 咏删,erase()惹想,clear()
    • 迭代訪問方法
      • 使用迭代器
    • 其他順序容器訪問方法(不修改訪問方法)
      • front(),back()督函,下標[ ]運算符

vector

  • 初始化 vector 容器方法

    1. vector<elementType> v; // 創(chuàng)建一個沒有任何元素的空容器
    2. vector<elementType> v(otherVec); //調用拷貝構造函數(shù)創(chuàng)建新容器
    3. vector<elementType> v(size); //創(chuàng)建一個大小為size的對象v嘀粱,并使用默認構造函數(shù)初始化該向量
    4. vector<elementType> v(n,elem); //創(chuàng)建一個大小為n的容器,并使用元素elem初始化每一個元素
    5. vector<elementType> v(begin,end); //創(chuàng)建容器v辰狡,并使用(begin锋叨,end)之間的元素初始化容器
  • 元素的插入

    1. veclist.push_back(elem); //將elem的一個拷貝插入到veclist的末尾
    2. veclist.insert(position,elem); //將elem的一個拷貝插入到指定的position的位置上
    3. veclist.insert(position,n,elem); //將elem的n個拷貝插入到由position指定的位置上
    4. veclist.insert(position,beg,end); //將從迭代器 beg至end-1 之間的元素插入到veclist 的position位置上
  • 元素的刪除

    1. veclist.clear(); //清空容器中所有元素
    2. veclist.erase(position); //刪除position指定位置的元素
    3. veclist.erase(beg,end); //刪除從beg至end-1之間的元素
    4. veclist.pop_back(); //刪除最后一個元素
  • 迭代器其他常用函數(shù)

    1. veclist.capacity(); //返回當前可插入到容器veclist的最大數(shù)(capacity是指容器在必須分配新的存儲空間之前可以存放的元素總數(shù))
    2. veclist.empty(); //判斷容器是否為空,為空返回true宛篇,否則返回false
    3. veclist.size(); //返回容器veclist 中當前元素個數(shù)
    4. veclist.max_size(); //返回可以插入到容器中元素的最大個數(shù)(max_szie表示STL容器允許的最大元素數(shù)娃磺,通常,這個數(shù)是一個很大的常整數(shù)叫倍,可以理解為無窮大偷卧。這個數(shù)目與平臺和實現(xiàn)相關)
  • vector使用

#include <iostream>
#include <vector>
using namespace std;
vector<int> v;
int main()
{
    int elem;
    //從標準輸入設備輸入整形
    //知道輸入的不是整形為止
    while(cin>>elem)
    {
        v.push_back(elem);
    }
    for(int j=0;j<v.size();j++)
    {
        cout<<v[j]<<" ";
    }
    cout<<endl;
    /*
    for (vector<int>::size_type ix = 0; ix != ivec.size(); ++ix) 
    {
        cout<<ivec[ix] <<endl; // 用下標方式訪問
    }
    */
    for(vector<int>::iterator it=v.begin();it<v.end();it++)
    {
        cout<<*it<<" ";
    }
    cout<<endl;
    for(vector<int>::reverse_iterator it=v.rbegin();it<v.rend();it++)
    {
        cout<<*it<<" ";
    }
    cout<<endl;
}
  • vector 與指針
#include <iostream>
#include <vector>
using namespace std;
int *p1;               //iterator i1;
const int *p2;         //const_iterator i2;
int *const p3;         //const iterator i3;
const int *const p4;   //const const_iterator i4;
void show(vector<int> vi)
{
    vector<int>::iterator it;
    it=vi.begin();
    while(it!=vi.end())
    {
        cout<<*it++<<' ';
    }   
    cout<<endl;
};
int main()
{
    vector<int> vi(3,90);
    show(vi);
    int a[5]={3,4,5,6,7};
    vi.insert(vi.begin(),a,a+5);
    show(vi);
    vi.push_back(100);
    show(vi);
    cout<<"size:"<<vi.size()<<endl;
    vi.assign(5,99);
    show(vi);
    cout<<"size:"<<vi.size()<<endl;
}

List

  • list的使用
    • list的四種構造函數(shù)
      1. list<elementType> L; //構造空容器L
      2. list<elementType> L(n, elem); //創(chuàng)建一個大小為size的對象L豺瘤,并使用elem元素進行初始化
      3. list<elementType> L(list1); //創(chuàng)建容器L,并使用已創(chuàng)建的容器list1進行初始化
      4. list<elementType> L(begin,end); //創(chuàng)建容器L涯冠,并使用(begin炉奴,end)之間的元素初始化容器
    • list元素的插入
      1. L.push_back(elem); //向容器的末尾插入元素elem的拷貝
      2. L.push_front(elem); //向容器的開端插入元素elem的拷貝
      3. L.insert(position, elem); //向容器的position位置插入元素elem的拷貝
      4. L.insert(position, n, elem); //向容器的position位置上插入元素elem的n個拷貝
      5. L.insert(position, beg, end); //將迭代器beg至 end-1 指向的內(nèi)容插入到容器的position位置上
      6. L.splice(position, list); //將鏈表容器list中的元素插入到position位置上,并且清空list容器
      7. L.splice(position, list, pos); //將容器list中的pos位置上的元素插入到position位置上蛇更,并將pos位置上的元素從list中移除
      8. L.splice(position, list, beg, end); //將容器list中beg 至 end-1 位置上的元素插入到position位置上瞻赶,并將這些元素從list中移除
    • 訪問容器元素
      1. List<elementType>::iterator i;
        使用begin, end 成員函數(shù)來操作

      2. List<elementType>::reverse_iterator ri;
        使用rbegin, rend 成員函數(shù)來操作

      3. List<elementType>::const_iterator ci;
        使用begin派任, end 成員函數(shù)來操作砸逊,但是只能訪問,不能進行修改

    • 元素的刪除
      1. L.pop_back(); //刪除容器的最后一個元素
      2. L.pop_front(); //刪除容器的第一個元素
      3. L.clear(); //刪除容器的所有元素
      4. L.erase(position); //刪除容器指定位置的元素
      5. L.erase(beg, end); //刪除迭代器beg 至 end-1 之間的元素
      6. L.remove(elem); //移除與元素elem相等的元素
#include <iostream>
using namespace std;
#include <list>
int main()
{
    int cpp[5]={3,6,1,7,5};
    int java[8]={6,4,7,8,15,2,3,9};
    int Unix[4]={5,2,6,9};
    list<int> li;
    li.insert(li.begin(),cpp,cpp+5);
    li.insert(li.begin(),java,java+8);
    li.insert(li.begin(),Unix,Unix+4);
    li.sort();
    li.unique();
    li.reverse();
    list<int>::iterator it=li.begin();
    while(it!=li.end())
    {   
        cout<<*it++<<' '; 
    }
    cout<<endl;
}
/*
15 9 8 7 6 5 4 3 2 1 
*/
#include <iostream>
#include <list>
using namespace std;
int main()
{
    list<int> l1;
    int a[5]={3,4,5,6,7};
    list<int> l2(a,a+5);
    cout<<"l1.size="<<l1.size()<<endl;
    cout<<"l2.size="<<l2.size()<<endl;
    list<int>::iterator it;
    for(it=l2.begin();it!=l2.end();it++)
    {
        cout<<*it<<' ';
    }
    cout<<endl;
    it=l2.begin();
    it++;
    l2.erase(it);//刪除it對應位置元素
    l2.insert(l2.begin(),100);
    l2.insert(l2.end(),200);
    for(it=l2.begin();it!=l2.end();it++)
    {
        cout<<*it<<' ';
    }
    cout<<endl;
}
l1.size=0
l2.size=5
3 4 5 6 7 
100 3 5 6 7 200 
  • map 使用
#include <iostream>
#include <map>
#include <string>
using namespace std;
int main()
{
    //key(是唯一的) value
    map<int,string> mis;
    //1. 插入map元素
    mis.insert(make_pair(62,"東方不敗"));
    mis.insert(make_pair(32,"岳不群"));
    mis.insert(make_pair(36,"林平之"));
    //2. 插入方式,這里的20不是下標
    mis[20]="勞德羅";
    //mis.insert(make_pair(36,"abc"));無法覆蓋
    //mis[36]="xyz";//可覆蓋
    map<int,string>::iterator it;
    it=mis.begin();
    //元素位置和key相關,和插入順序無關
    //1.自動順序的
    while(it!=mis.end())
    {
        cout<<it->first<<":"<<it->second<<endl;
        ++it;
    }
}
/*
20:勞德羅
32:岳不群
36:林平之
62:東方不敗
*/
  • 使用映射(map)建立阿拉伯數(shù)字0~9和英文單詞zero到nine的映射關系掌逛,并輸入阿拉伯數(shù)字(如1)师逸,輸出英文數(shù)字(如one)。
#include <iostream>
#include <map>
#include <string>
using namespace std;
int main()
{
    int num;
    map<int,string> mis;
    mis.insert(make_pair(0,"zero"));
    mis.insert(make_pair(1,"one"));
    mis.insert(make_pair(2,"two"));
    mis.insert(make_pair(3,"three"));
    mis.insert(make_pair(4,"four"));
    mis.insert(make_pair(5,"five"));
    mis.insert(make_pair(6,"six"));
    mis.insert(make_pair(7,"seven"));
    mis.insert(make_pair(8,"eight"));
    mis.insert(make_pair(9,"nine"));
    map<int,string>::iterator it;
    cin>>num;
    for(it=mis.begin();it!=mis.end();it++)
    {
        if(it->first==num)
            cout<<it->second<<endl;
    }
}
  • vector 實現(xiàn)刪除指定元素(vector<int> num,從控制臺輸入int填充vector豆混,刪除指定元素)
#include <iostream>
#include <vector>
using namespace std;
vector<int> vi;
int main()
{
    int elem;
    int place;
    while(cin>>elem)
    {
        vi.push_back(elem);
    }
    for(vector<int>::iterator it=vi.begin();it<vi.end();it++)
    {
        cout<<*it<<' ';
    }
    cout<<endl;
    for(vector<int>::iterator it1=vi.begin();it1<vi.end();)
    {
        if(*it1==3)
        {
            it1=vi.erase(it1);
            cout<<*it1<<endl;
        }
        else
            it1++;
    }
    for(vector<int>::iterator it2=vi.begin();it2<vi.end();it2++)
    {
        cout<<*it2<<' ';
    }
    cout<<endl;
}
  • const 的使用拓展
#include <iostream>
#include <vector>
using namespace std;
class Test
{
    int m_t;
    public:
        Test(){}
        void lianxi()const
        {
            cout<<"lianxi const"<<endl;
        }
        void lianxi()
        {
            cout<<"lianxi"<<endl;
        }
};
int main()
{
    const Test t1;
    t1.lianxi();
    Test t2;
    t2.lianxi();
}
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末篓像,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子皿伺,更是在濱河造成了極大的恐慌员辩,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,324評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鸵鸥,死亡現(xiàn)場離奇詭異奠滑,居然都是意外死亡,警方通過查閱死者的電腦和手機妒穴,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,356評論 3 392
  • 文/潘曉璐 我一進店門宋税,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人讼油,你說我怎么就攤上這事杰赛。” “怎么了矮台?”我有些...
    開封第一講書人閱讀 162,328評論 0 353
  • 文/不壞的土叔 我叫張陵淆攻,是天一觀的道長。 經(jīng)常有香客問我嘿架,道長瓶珊,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,147評論 1 292
  • 正文 為了忘掉前任耸彪,我火速辦了婚禮伞芹,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己唱较,他們只是感情好扎唾,可當我...
    茶點故事閱讀 67,160評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著南缓,像睡著了一般胸遇。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上汉形,一...
    開封第一講書人閱讀 51,115評論 1 296
  • 那天纸镊,我揣著相機與錄音,去河邊找鬼概疆。 笑死逗威,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的岔冀。 我是一名探鬼主播凯旭,決...
    沈念sama閱讀 40,025評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼使套!你這毒婦竟也來了罐呼?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 38,867評論 0 274
  • 序言:老撾萬榮一對情侶失蹤侦高,失蹤者是張志新(化名)和其女友劉穎弄贿,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體矫膨,經(jīng)...
    沈念sama閱讀 45,307評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,528評論 2 332
  • 正文 我和宋清朗相戀三年期奔,在試婚紗的時候發(fā)現(xiàn)自己被綠了侧馅。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,688評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡呐萌,死狀恐怖馁痴,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情肺孤,我是刑警寧澤罗晕,帶...
    沈念sama閱讀 35,409評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站赠堵,受9級特大地震影響小渊,放射性物質發(fā)生泄漏。R本人自食惡果不足惜茫叭,卻給世界環(huán)境...
    茶點故事閱讀 41,001評論 3 325
  • 文/蒙蒙 一酬屉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦呐萨、人聲如沸杀饵。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,657評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽切距。三九已至,卻和暖如春惨远,著一層夾襖步出監(jiān)牢的瞬間谜悟,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,811評論 1 268
  • 我被黑心中介騙來泰國打工锨络, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留赌躺,地道東北人。 一個月前我還...
    沈念sama閱讀 47,685評論 2 368
  • 正文 我出身青樓羡儿,卻偏偏與公主長得像礼患,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子掠归,可洞房花燭夜當晚...
    茶點故事閱讀 44,573評論 2 353

推薦閱讀更多精彩內(nèi)容

  • 前言: 詳細介紹: List:元素有放入順序领曼,元素可重復Map:元素按鍵值對存儲,無放入順序Set:元素無放入順序...
    YBshone閱讀 8,649評論 0 17
  • 模板 模板是C++語言相對較新的一個重要特性蛮穿。模板使程序員能夠快速建立具有類型安全的類庫集合和函數(shù)集合庶骄,它的實現(xiàn),...
    帥碧閱讀 948評論 2 4
  • 原其實也甚沒在意 你我的初遇 就像習慣著每天坐地鐵 這頭到那頭 最初日子里更是彼此恪盡職守 陌生人應有的默契 有時...
    為醉醇香也醉風月閱讀 176評論 2 2
  • 男人常嗤之以鼻女人間的友誼践磅。說女人間的友誼脆弱不堪单刁,說女人的友誼只在朋友圈,說女人在義氣方面只是口頭家…… 翻閱一...
    九丑_閱讀 477評論 6 6
  • 解構與?重構 分析馬斯克深化學習遷移的兩步法 1.把知識解構為若干基本原理 馬斯克發(fā)表在Reddit AMA上的回...
    Eddy君閱讀 2,098評論 0 0