现在的位置: 首页 > 综合 > 正文

几种STL中常用的容器和类2

2014年02月17日 ⁄ 综合 ⁄ 共 2319字 ⁄ 字号 评论关闭
一、       vector
1、              所需头文件:#include <string>
2、              定义:
typedef std::vector<element> synonym
别名 vecTest;
3、              几个常用的方法:
Ø         push_back
例:
typedef std::vector<string> VEC_T;
VEC_T vecTest;
vecTest.push_back(“abc”);
std::cout << vecTest.front() << endl;
结果:
    abc
Ø         insert
例:
typedef std::vector<string> VEC_T;
VEC_T vecTest;
VEC_T::iterator iter = vecTest.begin();
vecTest.insert(iter, “abc”);
std::cout << vecTest.front() << endl;
结果:
    abc
Ø         front
见上例。
Ø         遍历vector
例:
typedef std::vector<string> VEC_T;
VEC_T vecTest;
vecTest.push_back(“aaa”);
vecTest.push_back(“bbb”);
VEC::iterator iter;
for (iter = vecTest.begin(); iter != vecTest.end(); iter++)
{
std::cout << *iter << std::endl;
}
结果:
    aaa
    bbb
Ø         earse()
例:
typedef std::vector<string> VEC_T;
VEC_T vecTest;
vecTest.push_back(“aaa”);
vecTest.push_back(“bbb”);
VEC_T::iterator iter;
for (iter = vecTest.begin(); iter != vecTest.end(); iter++)
{
std::cout << *iter << std::endl;
}
iter = vecTest.begin();
vecTest.earse(iter);
for (iter = vecTest.begin(); iter != vecTest.end(); iter++)
{
std::cout << *iter << std::endl;
}
结果:
    aaa
    bbb
        bbb
Ø         size
Ø         pop_back
注意:如果vector是空的,将会抛出异常。
Ø         clear
注意:vector的operator[]符号虽然可以向vector中添加和修改数据,但这样做会有很多问题,最好不要这样用。
   vec[5] = 100;
二、       list
1、              所需头文件:#include <list>
2、              定义:
typedef std::list<element> synonym
别名 lstTest;
3、              几个常用的方法:
Ø         push_back
例:
typedef std::list<string> LIST_T;
LIST_T lstTest;
lstTest.push_back(“abc”);
std::cout << lstTest.front() << std::endl;
结果:
    abc
Ø         push_front
用法同上。
Ø         insert、front、遍历、clear、earse、size、pop_back、pop_front
用法同vector。
注意:list没有find方法,如果要查找list,则需要遍历。

 

 

一、       map
1、              所需头文件:#include <map>
2、              定义:
typedef std::map<key,element> synonym
别名 mapTest;
3、              几个常用的方法:
Ø         insert
例:
typedef std::map<int,string> MAP_T;
MAP_T mapTest;
mapTest.insert(MAP_T::value_type(1,“abc”));
std::cout << mapTest[1] << std::endl;
结果:
    abc
Ø         find
例:
typedef std::map<int, string> MAP_T;
MAP_T mapTest;
mapTest[1] = “aaa”;
mapTest[2] = “bbb”;
MAP_T::iterator iter = mapTest.find(2);
std::cout << iter->second << std::endl;
结果:
bbb
Ø         遍历
例:
typedef std::map<int, string> MAP_T;
MAP_T mapTest;
mapTest[1] = “aaa”;
mapTest[2] = “bbb”;
MAP_T::iterator iter;
for (iter = mapTest.begin(); iter != mapTest.end(); iter++)
{
std::cout << iter->second << std::endl;
}
结果:
    aaa
bbb
Ø         clear、size、earse
用法同vector。

 

抱歉!评论已关闭.