C++存储方案和动态分配
存储方案和动态分配
在之前的文章当中,我们讨论了C++用来为变量分配内存的5种方案,但是这些方案并不适用于使用new
运算符分配的内存,这种内存被称为动态内存。
我们在之前的文章当中也曾介绍过,动态内存由new
和delete
控制,而不是由作用域和链接性规则控制。所以我们可以在一个函数当中分配动态内存,在另外一个函数中释放。
通常C++编译器当中有三块独立的内存,一块用于静态变量,一块用于自动变量,还有一块用于动态存储。
虽然存储方案的概念不适用于动态内存,但是适用于动态内存的自动和静态指针。C++ Primer
当中有这么一个例子,我们在一个函数当中有如下语句:
float * p_fees = new float[20];
很明显,我们通过new
创建了一个长度为20的float
数组,这块数组的内存将会一直停留在内存当中,直到使用delete
语句释放。但当该函数运行结束的时候,p_fees
这个指针将会消失。如果希望在其他地方能够使用这个数组,需要将地址通过某种方式返回或者传递。
如果我们将p_fees
的链接性声明为外部的,那么我们在其他地方都可以访问到了,如果另外的文件当中需要访问,也同样可以使用关键字extern
。
初始化
前面讲了使用new
申请内存的方法,如果我们想要在分配内存的同时完成变量的初始化,应该怎么办呢?
如果要为内置的标量类型分配空间并初始化,可以在类型名后面加上初始值,并将它用括号括起来:
int *pi = new int(3); double *pd = new double(99.9);
如果我们要初始化结构体或者是数组,则需要使用大括号的列表初始化,这需要编译器支持C++11,这是C++11中的新特性:
struct P { int x, y; }; P *p = new P{3, 4}; int *arr = new int[4] {2, 3, 4, 5};
在C++11当中也支持对单值变量使用列表初始化:
double *pd = new double(99.99);
到此这篇关于C++存储方案和动态分配的文章就介绍到这了,更多相关C++存储方案和动态分配内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
最新评论