设为首页 加入收藏

TOP

2011年计算机二级C++辅导实例编程(19)
2014-10-20 14:30:03 来源: 作者: 【 】 浏览:45
Tags:2011年 计算机 二级 辅导 实例 编程

  C++中用vectors改进内存的再分配


  摘要:本文描述的是一种很常见的情况:当你在某个缓存中存储数据时,常常需要在运行时调整该缓存的大小,以便能容纳更多的数据。本文将讨论如何使用 STL 的 vector 进行内存的再分配。


  这里描述的是一种很常见的情况:当你在某个缓存中存储数据时,常常需要在运行时调整该缓存的大小,以便能容纳更多的数据。传统的内存再分配技术非常繁琐,而且容易出错:在 C 语言中,一般都是每次在需要扩充缓存的时候调用 realloc()。在 C++ 中情况更糟,你甚至无法在函数中为 new 操作分配的数组重新申请内存。你不仅要自己做分配处理,而且还必须把原来缓存中的数据拷贝到新的目的缓存,然后释放先前数组的缓存。本文将针对这个问题提供一个安全、简易并且是自动化的 C++ 内存再分配技术――即使用 STL 的 vector。


  用 STL vector 对象取代内建的数组来保存获取的数据,既安全又简单,并且是自动化的。


  进一步的问题分析


  在提出解决方案之前,我先给出一个具体的例子来说明 C++ 重新分配内存的弊病和复杂性。假设你有一个编目应用程序,它读取用户输入的 ISBNs,然后将之插入一个数组,直到用户输入 0 为止。如果用户插入的数据多于数组的容量,那么你必须相应地增加它的大小:


  #include


  using namespace std;


  int main()


  {


  int size=2; // 初始化数组大小;在运行时调整。


  int *p = new int[size];


  int isbn;


  for(int n=0; ;++n)


  {


  cout<< "enter an ISBN; press 0 to stop ";


  cin>>isbn;


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇2011年计算机二级C++辅导实例编程.. 下一篇2011年计算机二级C++辅导实例编程..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: