您的位置:首页 > 其它

第三章 字符串、向量和数组

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 )
...
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: