1. using声明和using指示html
using namespace std;---using 指示ios
using std::cin;---using 声明算法
http://blog.csdn.net/ljq32/article/details/7950629安全
http://blog.csdn.net/digu/article/details/1606563spa
2. const迭代器 const_iterator线程
vector<int> data(10);指针
const迭代器: const vector<int>::iterator iter=data.begin();htm
相似于常量指针,所指对象不可变,但能够改变所指对象的值
const_iterator: vector<int>::const_iterator iter=data.begin();
相似于指向常量的指针,所指对象能够变换,可是对象的值不容许改变。
3.stl的线程安全性
<<Effective STL>> tips 12:
1)在每次调用容器的成员函数期间都要锁定该容器。
2)在每一个容器返回的迭代器(例如经过调用begin或end)的生存期以内都要锁定该容器。
3)在每一个在容器上调用的算法执行期间锁定该容器。(这事实上没有意义,由于,正如条款32所解释的,算法没有办法识别出它们正在操做的容器。不过,咱们将在这里检验这个选项,由于它的教育意义在于看看为何即便是可能的它也不能工做。)
http://blog.csdn.net/zdl1016/article/details/4161427
4.文件结束符
EOF的两点总结(主要指普通终端中的EOF)
1.EOF做为文件结束符时的状况:
EOF虽然是文件结束符,但并非在任何状况下输入Ctrl+D(Windows下Ctrl+Z)都可以实现文件结束的功能,只有在下列的条件下,才做为文件结束符。
(1)遇到getcahr函数执行时,要输入第一个字符时就直接输入Ctrl+D,就能够跳出getchar(),去执行程序的其余部分;
(2)在前面输入的字符为换行符时,接着输入Ctrl+D;
(3)在前面有字符输入且不为换行符时,要连着输入两次Ctrl+D,这时第二次输入的Ctrl+D起到文件结束符的功能,至于第一次的Ctrl+D的做用将在下面介绍。
其实,这三种状况均可以总结为只有在getchar()提示新的一次输入时,直接输入Ctrl+D才至关于文件结束符。
http://blog.csdn.net/doupei2006/article/details/7447650
5.cin.clear()
iostream是由istream(输入流)和ostream(输出流)派生.因此在iostream中就有了输入和输出的相关对象:
一、cin 表示标准输入(standard input)的istream类对象,cin使咱们能够从设备读取数据。
二、cout 表示标准输出(standard output)的ostream类对象。对应于标准输出流,默认状况下是显示器。这是一个被缓冲的输出,能够被重定向。
三、cerr 对应标准错误流,用于显示错误消息。默认状况下被关联到标准输出流,但它不被缓冲,也就说错误消息能够直接发送到显示器,而无需等到缓冲区或者新的换行符时,才被显示。通常状况下不被重定向。
cout与cerr的区别:cout的输出能够重定向到一个文件中,而cerr必须输出在显示器上。
1. cin.get(),它是一个读取单个字符的方法。字符变量=cin.get(),至关于cin.get(字符变量)。
char cstr;
cstr = cin.get(); //读取单个字符,在屏幕输入,至关于cin.get(cstr);
cout<<cstr<<endl; //输出刚刚载入的单个字符
2.cin.getline(),则是获取一整行文本。如下是cin.getline()原形:
getline(char *line,int size,char='/n')
第一个是字符指针,第二个是字符长度,第三个为结束标识符。
cin.getline(str, sizeof(str), 'X'); //以单个英文字母'X'做为终止标识符
例六:
#include
using namespace std;
int main()
{
char str1[200];
char str2[200];
cin.getline(str1, sizeof(str1), 'X'); //以单个英文字母'X'做为终止标识符
cin.getline(str2, sizeof(str2), 'Y'); //以单个英文字母'Y'做为终止标识符
cout<<"第一行是:"<<str1<<endl; //输出
cout<<"第二行是:"<<str2<<endl;
system("pause");
}
输入:abcdXXXefghYYYigkl(回车)
输出: 第一行是:abcd
第二行是:XXefgh
如上可知,当遇到第一个结束符'X'结束输出abcd,以后遇到第一个结束符'Y'结束输出XXefgh。
3.
接下来谈谈cin.clear()的做用,第一次看到这东西,不少人觉得就是清空cin里面的数据流,而实际上却与此相差甚远,首先看看如下代码:
例七:
#include
using namespace std;
int main()
{
int a;
cin>>a;
cout<<cin.rdstate()<<endl;
if(cin.rdstate() == ios::goodbit)
{
cout<<"输入数据的类型正确,无错误!"<<endl;
}
if(cin.rdstate() == ios_base::failbit)
{
cout<<"输入数据类型错误,非致命错误,可清除输入缓冲区挽回!"<<endl;
}
system("pause");
}
咱们定义要输入的变量是整型,但若是输入了英文字母或者汉字,那就会发生错误,cin里有个方法能检测这个错误,就是cin.rdstate()。
当cin.rdstate()返回0(即ios::goodbit)时表示无错误,能够继续输入或者操做,若返回2则发生非致命错误即ios::failbit,则不能继续输入或操做。而cin.clear()则能够控制咱们此时cin里对这个问题的一个标识。语发以下:
cin.clear(标识符);
标识符号为:
经过cin.clear,咱们能确认它的内部标识符,若是输入错误则能从新输入。结合真正的清空数据流方法cin.sync(),请看下例:
例八:
#include
using namespace std;
int main()
{
int a;
while(true)
{
cin>>a;
if(!cin) //条件可改写为cin.fail()
{
cout<<"输入类型错误,请从新输入!"<<endl;
cin.clear(); //复位标志,将cin中的全部标志设置为有效状态
cin.sync(); //清空流
}
else
{
cout<<a<<endl;
break;
}
}
system("pause");
}
上面的cin默认值为非0,当输入为非整形时,它的状态标识符改成fail(即0),再用cin.clear()让错误标识改回为非0,能够继续输入,再清空流数据继续输入。若是没有了cin.clear(),则会进入死循环,其过程为咱们输入了英文字母,它的状态标识便为fail,当运行到条件判断时,便老是回到错误的条件表示里,而且再也没有办法输入,由于错误的表示关闭了cin,因此会进入死循环。能够分别注释掉cin.clear()和cin.sync()进行验证。
http://blog.sina.com.cn/s/blog_a6fb6cc90101bg1n.html