1,一个容器描述了一个持有其他对象的对象.
2,c++处理容器采用基于模板的方式.
3,针对不同的需要有不同类型的容器:如vector高效访问元素,list高效插入.
4,容器持有对象的要求:(1)可拷贝;(2)可赋值.
5,容器与容器的区别:(1)内存中存储对象的方式;(2)向用户提供了什么样的操作.
6,容器分类总结:
(1)序列容器(vector,list,dequeue):将元素线性的组织起来.
(2)容器适配器(queue,stack,priority_queue):序列附上某些特殊的属性.
(3)关联式容器(map,set,multiset,multimap):用关键字组织数据,允许快速访问.
7,如果容器是一个const容器,则begin()和end()产生const迭代器.
即:不允许更改这些迭代器指向的元素.
8,可逆容器的迭代器:rbegin(),rend().
实例代码:(将读入的文件,行倒序输出)
#include <fstream>
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int main()
{
ifstream in("main.cpp");
string line;
vector<string> lines;
while(getline(in, line))
lines.push_back(line);
for(vector<string>::reverse_iterator r = lines.rbegin();r != lines.rend(); r++)
cout << *r << endl;
return 0;
}
9,不同类型插入器的使用.
实例代码:
#include <iostream>
#include <vector>
#include <deque>
#include <list>
#include <iterator>
using namespace std;
int a[] = { 1, 3, 5, 7, 11, 13, 17, 19, 23 };
template<class T>
void frontInsertion(T& c)
{
copy(a,a+sizeof(a)/sizeof(a[0]),front_inserter(c));
copy(c.begin(),c.end(),ostream_iterator<typename T::value_type>(cout," "));
cout<<endl;
}
template<class T>
void backInsertion(T& c)
{
copy(a,a+sizeof(a)/sizeof(a[0]),back_inserter(c));
copy(c.begin(),c.end(),ostream_iterator<typename T::value_type>(cout," "));
cout<<endl;
}
template<class T>
void midInsertion(T& c)
{
typename T::iterator it = c.begin();
++it; ++it; ++it;//从第四个位置插入
copy(a, a + sizeof(a)/sizeof(typename T::value_type),inserter(c, it));
copy(c.begin(),c.end(),ostream_iterator<typename T::value_type>(cout," "));
cout << endl;
}
int main()
{
vector<int> vec;
list<int> lst;
deque<int> deq;
frontInsertion(deq);
frontInsertion(lst);
deq.clear();
lst.clear();
backInsertion(vec);
backInsertion(deq);
backInsertion(lst);
midInsertion(vec);
midInsertion(deq);
midInsertion(lst);
return 0;
}
10,比较流迭代器和流缓冲迭代器的使用:
实例代码:
#include <algorithm>
#include <fstream>
#include <iostream>
#include <iterator>
using namespace std;
int main()
{
ifstream in(__FILE__);
//注:都是直接操作字符
istreambuf_iterator<char> isb(in), end;
ostreambuf_iterator<char> osb(cout);
while(isb != end)
*osb++ = *isb++; // Copy 'in' to cout
cout << endl;
//使用流迭代器,将会吃掉空白字符.
ifstream in2(__FILE__);
istream_iterator<char> is(in2), end2;
ostream_iterator<char> os(cout);
while(is != end2)
*os++ = *is++;
cout << endl;
}
分享到:
相关推荐
根据提供的标题“GB 150.1-2011 压力容器 第1部分:通用要求”以及描述“GB 150.1-2011 压力容器 第1部分:通用要求”,我们可以了解到该标准是中国国家标准(GB),主要针对压力容器的通用要求进行规范。...
STL中的通用算法是一系列独立于容器的函数,可以用于处理各种容器内的元素。常见的通用算法有: 1. `std::sort`:对容器内的元素进行排序。 2. `std::find`:查找容器中是否存在特定元素。 3. `std::count`:统计...
罐头食品金属容器通用技术要求.pdf
纯C实现的通用红黑树容器不好找,于是自己琢磨着实现了一个。 算法部分直接剪裁自Linux内核中的rbtree 作者主要是在此基础上封装了一个通用的容器 里面含有 test例子 以及 benchmark基准测试 另外这个是Windows和...
压力容器制造通用检验规程完整.pdf
数据容器通用操作的具体代码
此外,还涉及了压力容器的使用寿命、腐蚀裕量、疲劳强度以及压力容器在极端环境下的适应性等通用性问题。 第二部分:材料 这一部分详细阐述了压力容器所用材料的选择和验证。它规定了钢材和其他金属材料的种类、...
这篇PPT教案主要介绍了容器通用零部件的相关知识,包括管子的公称尺寸、零部件的公称尺寸、公称压力PN的概念及其重要性,以及法兰连接的相关内容。公称尺寸是不同零部件相互配合的关键尺寸,而公称压力PN是零部件在...
泛型算法是一组通用的操作,定义在`<algorithm>`头文件中。这些算法不会直接修改容器的大小或删除元素,而是对容器中的元素进行操作。例如`sort`、`reverse`等。 #### 七、关联容器的操作 - **插入操作**:`insert`...
压力容器通用工艺守则资料.pdf
《储罐类容器制造通用工艺规程》是一份详细的制造指南,涵盖了从材料选择到最终检验和验收的全过程。这份规程适用于公司内部制造的各种储罐类容器,但不包括搅拌容器、换热容器和塔式容器。 规程的第一部分明确了其...
《压力容器制造通用工艺守则》是一份详细指导压力容器制造过程的标准文件,由某机械XX企业制定并发布。这份守则涵盖了从原材料选择到最终检验的各个环节,旨在确保压力容器的安全性和制造质量。 首先,守则明确了下...
在内容上,GB150.1《压力容器通用要求》的部分修订涉及了法兰设计计算的加强,如增加了整体法兰和任意式法兰的刚度校核计算,以及波齿垫片的设计选用要求。同时,标准的附录也进行了调整,如将原附录C的低温压力容器...
《压力容器制造通用工艺规程》是针对承压设备制造过程中的一项重要规范,旨在确保压力容器的安全性和可靠性。此规程详细规定了压力容器制造中的射线照相检测方法、底片质量和质量分级要求,以及相关工作人员的资格和...
《压力容器图样设计技术通用规定》是针对压力容器设计人员的重要指导文档,它规定了设计和绘制施工图的基本准则,确保了设计的规范性和一致性。该规定涵盖了多个方面,旨在确保压力容器的设计符合国家和行业的最新...
《储罐类容器制造通用工艺设计规程》是指导储罐制造过程的重要规范,它涵盖了从设计、材料选择、制造、检验到验收的整个流程。规程适用于公司内部制造的各类储罐,但不包括搅拌容器、换热容器和塔式容器。 在储罐的...
【压力容器制造通用检验规程】 压力容器制造过程中,质量控制是至关重要的环节,这涉及到生产安全和产品质量。本文档详细阐述了压力容器制造通用检验规程,涵盖了从原材料选购到最终产品的出厂检验。以下是对规程中...
钢制压力容器下料通用工艺守则.doc