该程序演示了vector中的元素为指针的时候的对对象的操作。

 /*
功能说明:
元素为指针的vector的使用说明
实现方式:
使用this成员来显示各个对象的地址。
限制条件或者存在的问题:

*/
#include <iostream>
#include <string>
#include <vector> using namespace std; class CData
{
public:
CData()
{
sequence = ;
this->remark = "default string"; cout << "CData()\t" << toString() <<"\t"<< this << endl;
} CData(int i,string &s)
{
this->sequence = i;
this->remark = s; cout << "CData(int i,string &s)\t" << toString() << "\t" << this << endl;
} void setSequence(const int i)
{
this->sequence = i;
} void setRemark(const string &s)
{
this->remark = s;
} string toString() const
{
char tmp[] = { };
sprintf(tmp, "[sequence:%d | remark:%s]", this->sequence, this->remark.c_str()); //此处应该有内存复制操作,所以不用担心返回后tmp数组所指向的内存被修改或者不存在的情况。
return tmp;
} ~CData()
{
cout << "~CData()\t" << this << endl;
}
protected:
private:
int sequence;
string remark;
}; int main(int argc, char **argv)
{
cout << "process begin at " << (void*)&main << endl; string str = "baby test";
// 查看保存在系统的栈中的对象的地址。
cout << "==========test class object in stack" << endl;
CData data1;
cout << "address of object in stack:" << &data1 << "\tdefalut object elements:" << data1.toString() << endl;
data1.setSequence();
data1.setRemark(str);
cout << "address of object in stack:" << &data1 << "\tafter set object elements:" << data1.toString() << endl; // 查看保存在系统的堆中的对象的地址。这种对象需要手工删除,否则会造成内存泄露
cout << "\n==========test class object in heap" << endl;
CData *p_data12 = new CData(, str); // 带有参数的构造函数的第二个参数为一个地址,所以,此处的调用必须为一个对象。不能是一个字符数组。
cout << "address of pointer of class object in stack:" << &p_data12 << "\taddress of class object in heap:" << p_data12 << "\tobject in heap:" << p_data12->toString() << endl; CData *p_data13 = new CData(, str);
cout << "address of pointer of class object in stack:" << &p_data13 << "\taddress of class object in heap:" << p_data13 << "\tobject in heap:" << p_data13->toString() << endl; cout << "\n==========vector test. object in heap" << endl;
vector<CData*> vec_data;
vec_data.push_back(p_data12);
vec_data.push_back(p_data13);
vec_data.push_back(p_data12);
vec_data.push_back(p_data13);
// 上述操作完成之后,堆中有2个对象,但是,这两个对象分别有3个指针来指向他。一个是原始的创建对象的时候的。另外两个是上面的push_back所复制的。
cout << "show vector's msg" << endl;
for (int i = ; i < vec_data.size(); i++)
{
// 查看vector元素的地址,说明,vector中的元素的位置是连续的。
cout << "address of element in vector:" << &(vec_data[i]) << endl;
CData *pTmp = vec_data[i];
cout << "object address in heap:" << pTmp << "\tobject msg in heap:" << (pTmp)->toString() << endl;
} vec_data.clear();
// 清理掉vector中的元素。也仅是清理掉vector中的指向对象的指针,并没有清理掉这些指针所指向的对象。另外,其原始的指向对象的指针还是存在的。
cout << "\n==========check objects in heap after clear vector" << endl;
cout << "address of class object in heap:" << p_data12 << "\tobject in heap:" << p_data12->toString() << endl;
cout << "address of class object in heap:" << p_data13 << "\tobject in heap:" << p_data13->toString() << endl; cout << "\n==========delete object in heap using vector iterator" << endl;
// 再将两个对象的指针复制到vector中。
vec_data.push_back(p_data12);
vec_data.push_back(p_data13);
for (vector<CData*>::iterator itr = vec_data.begin(); itr != vec_data.end(); itr++)
{
// 通过迭代器来删除每个指针指向的对象。如果vector中的多个元素指向了同一个对象(上面的情形),此处的程序会异常退出。
cout <<"delete object:" << *itr << endl;
delete *itr;
*itr = ;
} // 清理vector元素中的指针所指向的对象。并不意味着去清理了vector本身,所以,其长度还是原来的数值。
cout << "vector length is " << vec_data.size() << endl;
cout << "\n==========check objects in heap using vector after delete objects" << endl;
for (vector<CData*>::iterator itr = vec_data.begin(); itr != vec_data.end(); itr++)
{
// vecotr中的指针已经在上面被修改,这里是查看一下。
cout << "address of object in heap:" << *itr << endl;
} vec_data.clear(); cout << "\n==========check objects in heap using original pointer after delete objects" << endl;
// 上面的vector中,已经删除的堆中的对象。所以下面的对象的toString()操作将是错误的。使用此函数,会导致程序异常退出。
//cout << "address of class object in heap:" << p_data12 << "\tobject in heap:" << p_data12->toString() << endl;
//cout << "address of class object in heap:" << p_data13 << "\tobject in heap:" << p_data13->toString() << endl; // 上面的vector中,已经删除了堆中的对象。但是原始的指向对象的指针还是存在的,只不过是其指向的内存已经无效。
cout << "address of class object in heap:" << p_data12 << endl;
cout << "address of class object in heap:" << p_data13 << endl; // 此处相当于去删除一个无效的堆的对象,会导致程序异常退出。
//delete p_data12;
//delete p_data13; // 其所指向的对象已经在vector中删除,所以需要将其指向的地址清理掉,防止错误。
p_data12 = ;
p_data13 = ; cout << "process end " << (void*)&main << endl; // 程序退出前,会自动清理掉栈中的对象。 return ;
}

程序的输出结果:

process begin at 002D170D
==========test class object in stack
CData() [sequence:0 | remark:default string]    008FF9D8
address of object in stack:008FF9D8     defalut object elements:[sequence:0 | remark:default string]
address of object in stack:008FF9D8     after set object elements:[sequence:11 | remark:baby test]

==========test class object in heap
CData(int i,string &s)  [sequence:12 | remark:baby test]        00906BB8
address of pointer of class object in stack:008FF9CC    address of class object in heap:00906BB8        object in heap:[sequence:12 | remark:baby test]
CData(int i,string &s)  [sequence:13 | remark:baby test]        00902F30
address of pointer of class object in stack:008FF9C0    address of class object in heap:00902F30        object in heap:[sequence:13 | remark:baby test]

==========vector test. object in heap
show vector's msg
address of element in vector:0090B8E8
object address in heap:00906BB8 object msg in heap:[sequence:12 | remark:baby test]
address of element in vector:0090B8EC
object address in heap:00902F30 object msg in heap:[sequence:13 | remark:baby test]
address of element in vector:0090B8F0
object address in heap:00906BB8 object msg in heap:[sequence:12 | remark:baby test]
address of element in vector:0090B8F4
object address in heap:00902F30 object msg in heap:[sequence:13 | remark:baby test]

==========check objects in heap after clear vector
address of class object in heap:00906BB8        object in heap:[sequence:12 | remark:baby test]
address of class object in heap:00902F30        object in heap:[sequence:13 | remark:baby test]

==========delete object in heap using vector iterator
delete object:00906BB8
~CData()        00906BB8
delete object:00902F30
~CData()        00902F30
vector length is 2

==========check objects in heap using vector after delete objects
address of object in heap:00000000
address of object in heap:00000000

==========check objects in heap using original pointer after delete objects
address of class object in heap:00906BB8
address of class object in heap:00902F30
process end 002D170D
~CData()        008FF9D8

元素为指针的vector的使用说明的更多相关文章

  1. 小猪猪C++笔记基础篇(四)数组、指针、vector、迭代器

    小猪猪C++笔记基础篇(四) 关键词:数组,Vector. 一.数组与指针 数组相信大家学过C语言或者其他的语言都不陌生,简单的就是同一个变量类型的一组数据.例如:int a[10],意思就是从a开始 ...

  2. [C++程序设计]指向数组元素的指针

    如果先使p指向数组a的首元素(即p=a),则: (1) p++(或p+=1).使p指向下一元素,即a[1]. 如果用*p,得到下一个元素a[1]的值. (2) *p++.由于++和*同优先级,结合方向 ...

  3. Go 语言中的数组是一种 值类型(不像 C/C++ 中是指向首元素的指针)

    the-way-to-go_ZH_CN/07.1.md at master · Unknwon/the-way-to-go_ZH_CN https://github.com/Unknwon/the-w ...

  4. 【C语言】12-指向一维数组元素的指针

    一.用指针指向一维数组的元素 1 // 定义一个int类型的数组 2 int a[2]; 3 4 // 定义一个int类型的指针 5 int *p; 6 7 // 让指针指向数组的第0个元素 8 p ...

  5. 【C语言】指向一维数组元素的指针

    本文目录 一.用指针指向一维数组的元素 二.用指针遍历数组元素 三.指针与数组的总结 四.数组.指针与函数参数 前面我们已经学习了指针,如果指针存储了某个变量的地址,我们就可以说指针指向这个变量.数组 ...

  6. C 语言:返回两个数组中第一个相同元素的指针(我用了loop 、goto loop标签)

    // //  main.c //  Pointer_search // //  Created by ma c on 15/8/2. //  要求:通过指针查找,实现比较两个有序数组中的元素,输出两个 ...

  7. C语言:返回两个数组中第一个元素的指针,并输出这个值

    // //  main.c //  Pointer_search // //  Created by ma c on 15/8/2. //  Copyright (c) 2015年. All righ ...

  8. 【C语言】-指向一维数组元素的指针

    本文目录 一.用指针指向一维数组的元素 二.用指针遍历数组元素 三.指针与数组的总结 四.数组.指针与函数参数 说明:这个C语言专题,是学习iOS开发的前奏.也为了让有面向对象语言开发经验的程序员,能 ...

  9. 数组元素的删除 【vector】

    7-5 数组元素的删除(5 分) 完成数组元素的移动功能:假设数组有n个元素,输入一个数x,把数组的第x个位置的元素删除了,后面的元素依次前进一个位置. 重复若干次这样的删除,得到最后的结果. 输入格 ...

随机推荐

  1. Django 项目补充知识(JSONP,前端瀑布流布局,组合搜索,多级评论)

    一.JSONP 1浏览器同源策略 通过Ajax,如果在当前域名去访问其他域名时,浏览器会出现同源策略,从而阻止请求的返回 由于浏览器存在同源策略机制,同源策略阻止从一个源加载的文档或脚本获取或设置另一 ...

  2. 前端 JavaScript&Dom

    JavaScript是一种属于网络的脚本语言,已经被广泛用于Web应用开发,常用来为网页添加各式各样的动态功能,为用户提供更流畅美观的浏览效果.通常JavaScript脚本是通过嵌入在HTML中来实现 ...

  3. 架构在APP和前端里的应用和演进

    架构设计相关的理念.技术.实践,比如存储高可用.微服务.异地多活等,都是后端系统才会涉及.事实上确实也是如此,通常情况下我们讲架构设计,主要聚焦在后端系统,但这并不意味着 App.前端就没有架构设计了 ...

  4. ssh登陆virtualbox虚拟机

  5. Dubbo框架入门介绍

    背景 随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进. 单一应用架构 当网站流量很小时,只需一个 ...

  6. 计算机网络概述---传输层 UDP和TCP

    传输层的功能 传输层为应用进程间提供端到端的逻辑通信(网络层是提供主机之间的逻辑通信), 传输层两大重要的功能:复用 和 分用. 复用:在发送端,多个应用进程公用一个传输层: 分用:在接收端,传输层会 ...

  7. ubuntu没有声音解决办法

    cd /usr/lib/dbus-1.0/ chmod +x dbus-daemon-launch-helper sudo gpasswd -a $USER audio sudo killall pu ...

  8. C#多线程学习之:Monitor类

    关于对C#多线程类Monitor的理解 1.对线程的理解 围绕着锁周围的线程可以分为以下三类: l  拥有锁的线程:只有一个 l  就绪队列:只有就绪队列里的线程才有机会在锁被释放时去获取锁. l  ...

  9. Oracle常用知识小总结

    永不放弃,一切皆有可能!!! 只为成功找方法,不为失败找借口! Oracle常用知识小总结 1. 创建自增主键 对于习惯了SQL SERVER的图形化界面操作的SQLer,很长一段时间不用oracle ...

  10. 一言(ヒトコト)Hitokoto API

    『想要成为无论多么悲伤的时候,也能够漂亮微笑的人吧.』 Hitokoto API 更新:2014.02.22 问题/反馈:api # hitokoto.us 数据获取:[ 数据获取 ] 调用举例:[  ...