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

头文件中不应当包含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 )
            ...
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值