跳转到内容
主菜单
主菜单
移至侧栏
隐藏
导航
首页
最近更改
随机页面
MediaWiki帮助
代码酷
搜索
搜索
中文(中国大陆)
外观
创建账号
登录
个人工具
创建账号
登录
未登录编辑者的页面
了解详情
贡献
讨论
编辑“︁
C++ 序列容器
”︁(章节)
页面
讨论
大陆简体
阅读
编辑
编辑源代码
查看历史
工具
工具
移至侧栏
隐藏
操作
阅读
编辑
编辑源代码
查看历史
常规
链入页面
相关更改
特殊页面
页面信息
外观
移至侧栏
隐藏
您的更改会在有权核准的用户核准后向读者展示。
警告:
您没有登录。如果您进行任何编辑,您的IP地址会公开展示。如果您
登录
或
创建账号
,您的编辑会以您的用户名署名,此外还有其他益处。
反垃圾检查。
不要
加入这个!
== 详细容器说明 == === std::vector === '''动态数组''',在堆上分配连续内存空间,支持快速随机访问。当容量不足时会自动重新分配内存(通常以2倍大小增长)。 ==== 基本操作示例 ==== <syntaxhighlight lang="cpp"> #include <vector> #include <iostream> int main() { std::vector<int> nums = {1, 2, 3}; // 初始化 // 添加元素 nums.push_back(4); // 尾部插入 nums.insert(nums.begin(), 0); // 头部插入 // 访问元素 std::cout << "第一个元素: " << nums[0] << '\n'; std::cout << "最后一个元素: " << nums.back() << '\n'; // 遍历 for(int num : nums) { std::cout << num << ' '; } return 0; } </syntaxhighlight> 输出: <pre> 第一个元素: 0 最后一个元素: 4 0 1 2 3 4 </pre> ==== 内存管理 === vector的内存增长可以通过以下公式描述: <math> capacity_{new} = max(2 \times capacity_{current}, size_{required}) </math> === std::deque === '''双端队列''',由多个固定大小的数组块组成,支持在头部和尾部高效插入/删除。 <mermaid> graph LR A[块1] --> B[块2] --> C[块3] A -->|前端| Front C -->|后端| Back </mermaid> ==== 示例代码 ==== <syntaxhighlight lang="cpp"> #include <deque> #include <iostream> int main() { std::deque<std::string> lines; // 双端操作 lines.push_back("World"); lines.push_front("Hello"); lines.push_back("!"); for(const auto& line : lines) { std::cout << line << ' '; } return 0; } </syntaxhighlight> 输出: <pre> Hello World ! </pre> === std::list 和 std::forward_list === 链表结构,区别在于双向和单向链接。 ==== 链表操作示例 ==== <syntaxhighlight lang="cpp"> #include <list> #include <algorithm> int main() { std::list<int> data = {2, 4, 6}; // 高效插入 data.insert(data.begin(), 0); // 头部插入 auto it = std::find(data.begin(), data.end(), 4); data.insert(it, 3); // 在4前插入3 // 高效删除 data.remove(6); // 删除所有6 // 链表特有操作 data.sort(); // 排序 data.unique(); // 去重 return 0; } </syntaxhighlight> === std::array === '''固定大小数组''',包装了C风格数组,提供STL接口。 <syntaxhighlight lang="cpp"> #include <array> #include <iostream> int main() { std::array<int, 3> arr = {1, 2, 3}; // 安全访问 try { std::cout << arr.at(4); // 抛出std::out_of_range } catch(const std::exception& e) { std::cerr << e.what(); } // 编译时大小检查 static_assert(arr.size() == 3, "大小必须为3"); return 0; } </syntaxhighlight>
摘要:
请注意,所有对代码酷的贡献均被视为依照知识共享署名-非商业性使用-相同方式共享发表(详情请见
代码酷:著作权
)。如果您不希望您的文字作品被随意编辑和分发传播,请不要在此提交。
您同时也向我们承诺,您提交的内容为您自己所创作,或是复制自公共领域或类似自由来源。
未经许可,请勿提交受著作权保护的作品!
取消
编辑帮助
(在新窗口中打开)