C/C++ 第 12 课 动态内存、命名空间

1、C++ 程序中的内存分为两个部分:

栈: 在函数内部声明的所有变量都将占用栈内存。
堆: 这是程序中未使用的内存,在程序运行时可用于动态分配内存。

2、前提:无法提前预知需要多少内存来存储某个定义变量中的特定信息,所需内存的大小需要在运行时才能确定。

在 C++ 中,您可以使用特殊的运算符为给定类型的变量在运行时分配堆内的内存,这会返回所分配的空间地址。这种运算符即 new 运算符
如果您不再需要动态分配的内存空间,可以使用 delete 运算符,删除之前由 new 运算符分配的内存。

3、new

通用语法:new data-type

data-type可以是:包括 数组在内的任意内置的数据类型,也可以是包括类或结构 在内的用户自定义的任何数据类型。

注意点:

如果自由存储区已被用完,可能无法成功分配内存。所以建议检查 new 运算符是否返回 NULL 指针,并采取以下适当的操作:

// new 返回的 是 分配空间的 地址,这里我们要使用 指针
double* pvalue  = NULL;
if( !(pvalue  = new double ))
{
   cout << "Error: out of memory." <

malloc() 函数在 C 语言中就出现了,在 C++ 中仍然存在,但建议尽量不要使用 malloc() 函数。new 与 malloc() 函数相比,其主要的优点是,new 不只是分配了内存,它还创建了对象。

Why? malloc 的内存在 堆 中, new 的内存在哪里?

在任何时候,当您觉得某个已经动态分配内存的变量不再需要使用时,您可以使用 delete 操作符释放它所占用的内存

delete pvalue;        // 释放 pvalue 所指向的内存

4、 命名空间

定义:作为附加信息来区分不同库中相同名称的函数、类、变量等。使用了命名空间即定义了上下文。本质上,命名空间就是定义了一个范围。
关键字:namespace XX {}
使用:调用XX 中的方法的时候,使用XX:: + 方法名称
using namespace XX : 这个指令告诉 编译器 下面的代码 将 使用 XX 的 命名空间。也就是说如果有相同的方法,调用的是 XX 命名空间中的方法

你可能感兴趣的:(C/C++ 第 12 课 动态内存、命名空间)