头文件中不应当包含using声明,以防止其他文件包含的时候出现名字冲突
一般初始化时,分为直接初始化和拷贝初始化(需要用到等于‘=’号),而初始值只有一个时,都可以,为多个时,一般采用直接初始化(当然也可构建临时对象)
string从第一个字符开始读取(忽略前面的空格、制表符、换行符等空白)
getline,读取一行,直到换行符为止,并且
换行符不会被保存至string对象中
string的加法中,必须保证
两端至少有一个是 string类型,且
字符串字面值并不是string类型
3.2拷贝初始化和直接初始化的含义
string s = "123"; //拷贝初始化
string b( "123" ); //直接初始化
string c( 10 , "1" ); //直接初始化
3.3标准库类型vector(是一个类模板)
模板本身不是类或函数,可以看出
编译器生成对应类或函数的说明,
编译器根据模板vector生成几种不同类型,如:vector<int>、vector<Sales_items>、vector<vector<string> >
老方法,定义vector中的vector是,需要
vector<vector<string> > (中间有空格)
任何一个
改变容器容量 的操作,都会使
迭代器失效
迭代器的减法,表示两个迭代器的
距离,类型为difference_type
数组指针的减法,类型
为ptrdiff_t的标准库类型
3.5数组
不能用一个数组
初始化 另一个数组!!!
阅读
数组声明时,
由内向外,由右向左的读法理解
int b[10];
auto a( b ) ;
//
auto a( &b[0] ) ;
所以,a是int *类型的
decltype c( b ) ; //
b是int[10]类型的
int * p[20]; // p是一个拥有20个int 指针的数组
constexpr size_t = 5
int a[size_t] = {1,2,3,4,5};
int *p = a + size_t; //指向数组尾元素的下一个位置,
为什么不是未定义的?(我觉得是因为存在尾后元素这个说法,需要有这个对象来表明数组的结束,从end(a)这个标准库函数存在的理由,进而推测)
int *sp = a + 10; //指向为未知位置
数组初始化vector的时候:
int a[5] = {1,2,3,4,5};
vector<int> a ( begin(a) , a+3 ); // 第一个表示元素的起点,
第二个表明,末尾元素的下一位置
int a[5] = {1,2,3,4,5};
for( const auto & row , a ) // 使用const auto & 的原因,
避免row被转换成int *类型
for( auto col , row )
...