工作问题记录——STL容器(保持更新)

ps:(本来一些自己的学习记录放在本地的,上次电脑崩了就很糟心,想了想还是放在博客上,保持更新即可,如有错误欢迎指正。另外这个不是介绍博客,就是我的一些总结而已。)

STL容器

1.array容器

  1. Array静态容器数组,比一般静态数组更安全,因为加了越界检查,通过at()函数,例如:
std::array<class T,auto N> values; 
values[1]=values.at(1);    //这边就可以进行越界检查

2.vector容器

  1. 在初始化vector时,如果仅仅 vector<T> v; 这时候v的size为0,如果直接进行访问 v[i] 会报错。 这里可以使用 v.resize(n),或者v.resize(n, m) 来初始化 前者是使用n个0来初始化,后者是使用n个m来初始化。
    如果直接vector<T> v; 只能用push_back进行赋值 。
    初始化可以这样vector<T> V(n);或者vector<T> v(n,m);
  2. 要想接收stl迭代器的返回值,需要申明迭代器,通过迭代器去访问数据。(当然了迭代器本身也是沟通算法和容器的桥梁。)
     vector<int>::iterator pd=xx.begin();
     *pd=returndata;//这就是返回值,如果用int* 去接收会报错

3.map容器

  1. map是集合型的容器不能直接进行sort排序,只有线性才行,如果key不是int型,会按照字典型进行排序,如果想改变可以重载map<key,value,lesser/greater>第三个参数,
    重要)如果想按照vlalue进行排序,比如value是int,可以将map都存储在vector中,然后用线性sort来排序。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
侯捷的《STL源码剖析》是一本关于STL(标准模板库)的学习笔记。这本书深入解析了STL的实现原理和设计思路,对于理解STL的内部机制和使用方法非常有帮助。这些学习笔记记录了作者在学习侯捷的《STL标准库和泛型编程》课程时的心得和总结,对于理解STL源码和进行泛型编程都具有指导意义。 这本书涉及了STL的各个模块,包括容器、迭代器、算法等,并解释了它们的实现原理和使用方法。通过学习这本书,你可以更好地理解STL的底层实现和使用技巧。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [STLSourceAnalysis:stl原始码剖析(侯捷)的学习笔记](https://download.csdn.net/download/weixin_42175776/16069622)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [候捷老师STL源码剖析视频课程笔记](https://blog.csdn.net/weixin_46065476/article/details/125547869)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [侯捷——STL源码剖析 笔记](https://blog.csdn.net/weixin_45067603/article/details/122770539)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值