第三章 字符串、向量和数组
2015-02-05 15:46
169 查看
头文件中不应当包含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 )
...
一般初始化时,分为直接初始化和拷贝初始化(需要用到等于‘=’号),而初始值只有一个时,都可以,为多个时,一般采用直接初始化(当然也可构建临时对象)
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 )
...
相关文章推荐
- 第三章字符串,向量,数组
- 菜狗的C++ primer读书笔记:第三章 字符串、向量和数组
- [C++ primer]第三章笔记--字符串、向量和数组
- c++ primer(第五版)学习笔记及习题答案代码版(第三章)字符串、向量和数组
- 第三章 字符串、向量和数组学习笔记(第一遍阅读)
- C++ Primer学习笔记之第三章--字符串,向量和数组
- 第三章 字符串、向量和数组(重点)
- 第三章 字符串、向量和数组
- 《C++primer(第五版)》学习之路-第三章:字符串、向量和数组
- 第三章 字符串、向量和数组
- C++ Primer中文版(第五版)--第三章 字符串、向量和数组
- c++ primer概念整理第三章 字符串,向量,数组
- 第三章 字符串、向量和数组
- C++ Primer 笔记——第三章 字符串、向量和数组
- c++ primer第三章 - 字符串、向量、数组
- 《C++ Primer 第五版》学习笔记-第三章-字符串、向量和数组
- C++学习笔记 | 第三章 字符串、向量和数组 | (1)
- C++ Primer | 第三章 字符串、向量和数组
- 第三章 字符串、向量、数组
- 第三章 字符串,向量和数组