#include<iostream>
using namespace std;
const int size = ;
double buf[size] = {}; int main(int argv ,char * args[]) { double *p1,*p2;
p1 = new double[size];
p2 = new (buf)double[size];
for (int i = ; i < size; i++) {
p1[i]=p2[(i+)%size]=i+;
cout << "p1== " << &p1[i] << " p1[i]=="<<p1[i]<<" "<< endl;
}
cout << "---------------华丽丽的分割线-----------------------" << endl;
for (int i = ; i < size; i++) {
cout << "p2== " << &p2[i] << " p2[i]==" << p2[i] << " " << endl;
}
cout << "---------------一大波内存袭来!-----------------------" << endl;
double *p3, *p4;
p3 = new double[size];
p4 = new (buf)double[size];
for (int i = ; i < size; i++) {
p3[i] = p4[(i + ) % size] = i + ;
cout << "p3== " << &p3[i] << " p3[i]==" << p3[i] << " " << endl;
}
cout << "---------------华丽丽的分割线-----------------------" << endl;
for (int i = ; i < size; i++) {
cout << "p4== " << &p4[i] << " p4[i]==" << p4[i] << " " << endl;
}
cout << "###################华丽丽的分割线########################" << endl;
//数组指针
double *p[] = {p1,p2,p3,p4};
for (int i = ; i < ; i++)
for (int j = ; j < size; j++) {
cout << "p["<<i<<"]== " << &p[i][j] << " p["<<i<<"]"<<"["<<j<<"]==" << p[i][j] << " " << endl;
} for (int i = ; i < ; i++) {
//释放new创建的内存
if (p[i]!=buf) delete [] p[i] ;
}
cout << "内存释放之后" << endl;
for (int i = ; i < size; i++) { cout << "p1== " << &p1[i] << " p1[i]==" << p1[i] << " " << endl;
}
cin.get();
return ;
}
 p1== 0038DC28    p1[i]==
p1== 0038DC30 p1[i]==
p1== 0038DC38 p1[i]==
p1== 0038DC40 p1[i]==
p1== 0038DC48 p1[i]==
p1== 0038DC50 p1[i]==
p1== 0038DC58 p1[i]==
p1== 0038DC60 p1[i]==
p1== 0038DC68 p1[i]==
p1== 0038DC70 p1[i]==
---------------华丽丽的分割线-----------------------
p2== 0125C2D0 p2[i]==
p2== 0125C2D8 p2[i]==
p2== 0125C2E0 p2[i]==
p2== 0125C2E8 p2[i]==
p2== 0125C2F0 p2[i]==
p2== 0125C2F8 p2[i]==
p2== 0125C300 p2[i]==
p2== 0125C308 p2[i]==
p2== 0125C310 p2[i]==
p2== 0125C318 p2[i]==
---------------一大波内存袭来!-----------------------
p3== 0038B1F8 p3[i]==
p3== 0038B200 p3[i]==
p3== 0038B208 p3[i]==
p3== 0038B210 p3[i]==
p3== 0038B218 p3[i]==
p3== 0038B220 p3[i]==
p3== 0038B228 p3[i]==
p3== 0038B230 p3[i]==
p3== 0038B238 p3[i]==
p3== 0038B240 p3[i]==
---------------华丽丽的分割线-----------------------
p4== 0125C2D0 p4[i]==
p4== 0125C2D8 p4[i]==
p4== 0125C2E0 p4[i]==
p4== 0125C2E8 p4[i]==
p4== 0125C2F0 p4[i]==
p4== 0125C2F8 p4[i]==
p4== 0125C300 p4[i]==
p4== 0125C308 p4[i]==
p4== 0125C310 p4[i]==
p4== 0125C318 p4[i]==
###################华丽丽的分割线########################
p[]== 0038DC28 p[][]==
p[]== 0038DC30 p[][]==
p[]== 0038DC38 p[][]==
p[]== 0038DC40 p[][]==
p[]== 0038DC48 p[][]==
p[]== 0038DC50 p[][]==
p[]== 0038DC58 p[][]==
p[]== 0038DC60 p[][]==
p[]== 0038DC68 p[][]==
p[]== 0038DC70 p[][]==
p[]== 0125C2D0 p[][]==
p[]== 0125C2D8 p[][]==
p[]== 0125C2E0 p[][]==
p[]== 0125C2E8 p[][]==
p[]== 0125C2F0 p[][]==
p[]== 0125C2F8 p[][]==
p[]== 0125C300 p[][]==
p[]== 0125C308 p[][]==
p[]== 0125C310 p[][]==
p[]== 0125C318 p[][]==
p[]== 0038B1F8 p[][]==
p[]== 0038B200 p[][]==
p[]== 0038B208 p[][]==
p[]== 0038B210 p[][]==
p[]== 0038B218 p[][]==
p[]== 0038B220 p[][]==
p[]== 0038B228 p[][]==
p[]== 0038B230 p[][]==
p[]== 0038B238 p[][]==
p[]== 0038B240 p[][]==
p[]== 0125C2D0 p[][]==
p[]== 0125C2D8 p[][]==
p[]== 0125C2E0 p[][]==
p[]== 0125C2E8 p[][]==
p[]== 0125C2F0 p[][]==
p[]== 0125C2F8 p[][]==
p[]== 0125C300 p[][]==
p[]== 0125C308 p[][]==
p[]== 0125C310 p[][]==
p[]== 0125C318 p[][]==
内存释放之后
p1== 0038DC28 p1[i]==-1.45682e+144
p1== 0038DC30 p1[i]==-1.45682e+144
p1== 0038DC38 p1[i]==-1.45682e+144
p1== 0038DC40 p1[i]==-1.45682e+144
p1== 0038DC48 p1[i]==-1.45682e+144
p1== 0038DC50 p1[i]==-1.45682e+144
p1== 0038DC58 p1[i]==-1.45682e+144
p1== 0038DC60 p1[i]==-1.45682e+144
p1== 0038DC68 p1[i]==-1.45682e+144
p1== 0038DC70 p1[i]==-1.45682e+144

这样,可以对内存进行很好的利用,避免内存泄露。而导致系统运行越来越慢!

C++ 如何重复利用一个内存地址块的更多相关文章

  1. 理解C指针: 一个内存地址对应着一个值

    一个内存地址存着一个对应的值,这是比较容易理解的. 如果程序员必须清楚地知道某块内存存着什么内容和某个内容存在哪个内存地址里了,那他们的负担可想而知.    汇编语法对“一个内存地址存着一个对应的数” ...

  2. golang中内存地址计算-根据内存地址获取下一个内存地址对应的值

    package main import ( "fmt" "unsafe" ) func main() { // 根据内存地址获取下一个字节内存地址对应的值 da ...

  3. 汇编语言 Part 1——简介、基本语法、内存分段与内存地址

    简介 什么是汇编语言? 汇编语言是一种低级的编程语言,在程序的语句和体系结构的机器代码指令之间有很强的对应关系. 每种汇编语言都特定于特定的计算机体系结构,但需要解释或编译.汇编语言也可以称为符号机器 ...

  4. 16.C语言中数据类型的本质含义是:表示一个内存格子的长度和解析方法。

    数据类型决定长度的含义:我们一个内存地址(0x30000000),本来这个地址只代表1个字节的长度,但是实际上我们可以通过给他一个类型(int),让他有了长度(4),这样这个代表内存地址的数字(0x3 ...

  5. c语言中通过指针将数值赋值到制定内存地址

    1.一种直观的方法 假设现在需要往内存0x12ff7c地址上存入一个整型数0x100.我们怎么才能做到呢? 我们知道可以通过一个指针向其指向的内存地址写入数据,那么这里的内存地址0x12ff7c其本质 ...

  6. [转,讲的非常精彩]CIDR地址块及其子网划分(内含原始IP地址分类及其子网划分的介绍)

    http://blog.csdn.net/dan15188387481/article/details/49873923 CIDR地址块及其子网划分(内含原始IP地址分类及其子网划分的介绍)   1. ...

  7. day06 内存地址 小数据池缓存机制

    1. 内存相关 示例一 v1=[11,22,33] v2=[11,22,33] #值相等 内存地址不等 v1=11 v2=11 #按理说内存地址应该不等,但是python为了优化使其内存地址相等 v1 ...

  8. CIDR概述及其地址块计算

    CIDR概述 英文:Classless Inter-Domain Routing,中文是:无分类域间路由选择.一般叫做无分类编址. 设计目的:解决路由表项目过多过大的问题. 表示法:{<网络前缀 ...

  9. C之内存地址

    计算机的内存地址 * 32位系统最多能识别4G内存 * 32位系统的地址总线长度是32位的,也就是说能分配给内存地址的数字是 2的32次方个 * 内存中每一个字节都需要一个内存地址 * 一个数字对用一 ...

随机推荐

  1. 昂贵的聘礼 Dijkstra法

    poj 1062 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 39437   Accepted: 11432 Descri ...

  2. window server开发

    代码部分: public partial class tv : ServiceBase { public tv() { InitializeComponent(); ServiceName = &qu ...

  3. Installing Chocolatey

    https://chocolatey.org/install To install chocolatey now, open an administrative command prompt and ...

  4. genome MuSic安装

    系统:ubuntu 15.04全程在root权限下安装 首先安装软件samtools ,必须是samtools-0.1.19 版本tar jxf samtools-0.1.19.tar.bz2cd s ...

  5. 历史命令history

    历史命令在用户注销之后会保存在用户家目录下的-/.bash_history中 history #查看系统中实时缓存的历史命令,与.bash_history中的内容并不完全相同 history -c # ...

  6. 关于Java控制台输入输出乱码问题

    产生原因:因为这个开源项目的默认字符编码为UTF-8,所以我的控制台的字符编码也自动变成了UTF-8,而键盘的输入流的默认格式是GBK格式,这样就造成了在GBK转UTF-8的过程中产生的奇数乱码错误( ...

  7. windos命令行下的程序编写

    1.命令行下写程序. 写程序一定要用IDE?不,我还可以用记事本呢.呵呵,写程序一定要用记事本?? ———————————————— 命令行下输入copy con test.txt后回车可在相应目录下 ...

  8. hdu 1142 用优先队列实现Dijkstra

    之前很认真地看了用优先队列来实现Dijkstra这块,借鉴了小白书上的代码模板后,便拿这道题来试试水了.这道题的大意就是问你从地点1到地点2有多少条满足条件的路径(假设该路径经过 1->...- ...

  9. bignum 大数模板

    今天无意间看到一个很好的大数模板,能算加.减.乘.除等基本运算,但操作减法的时候只能大数减小数,也不支持负数,如果是两个负数的话去掉符号相加之后再取反就可以了,一正一负比较绝对值大小,然后相减.我借用 ...

  10. html5移动端制作知识点总结

    一.测试工具:1.Chrome 2.Opera Mobile二.分辨率:一般现代手机最小320px,最大640px.三.全屏流体设计: 1.腾讯新闻:http://xw.qq.com/ 2.途牛旅游: ...