详解C++ 动态内存分配与命名空间

所属分类: 软件编程 / C 语言 阅读数: 107
收藏 0 赞 0 分享

1、C++中的动态内存分配

  • 通过new关键字进行动态内存申请
  • C++中的动态内存申请时基于类型进行的
  • delete关键用于内存释放

C语言其实是不支持动态内存分配的,是通过malloc库函数来实现的,可能有一些硬件根本不支持malloc;而C++ new是一个关键字,不管在任意编译器上,任意硬件平台上都是能够进行动态内存分配的,这是本质区别。

malloc是基于字节来进行动态内存分配的,new则是基于类型来进行动态内存分配

// 变量申请:
Type * pointer = new Type;  // 从堆空间获取一个新的Type类型的空间
// 使用和C语言一样
delete pointer;    // 这里指的是pointer所指向的那个元素的内存空间被释放

// 数组申请:
Type * pointer = new Type[N];  // N指数组大小,数组元素个数,并非字节数
// 
delete[] pointer;  // 数组的释放,需要在delete后面加[],和变量有区别
          // delete[] 说明所要释放的指针是指向一片数组空间的,释放整个数组空间,如果用delete的话,pointer指向的是数组的首元素地址,释放的就是首元素的内存空间,其余元素的内存空间并没有释放,会造成内存泄漏
#include <stdio.h>

int main()
{
  int* p = new int;  
  
  *p = 5;
  *p = *p + 10;
  
  printf("p = %p\n", p);
  printf("*p = %d\n", *p);
  
  delete p;    // 指释放单个变量
  
  p = new int[10]; // p指向一片数组空间,
  // p所指向的内存空间,至少占用了40个字节,保证够用,可能分配得更多
  
  for(int i=0; i<10; i++)
  {
    p[i] = i + 1;
    
    printf("p[%d] = %d\n", i, p[i]);
  }
  
  delete[] p;  // 释放数组
  
  return 0;
}

new关键字与malloc函数的区别:

  • new关键字是C++的一部分
  • malloc是由C库提供的函数
  • new以具体的类型为单位进行内存分配
  • malloc以字节为单位进行内存分配
  • new在申请单个类型变量时可以进行初始化
  • malloc不具备内存初始化的特性

new关键字的初始化:

int*  pi = new int(1);
float* pf = new float(2.0f);
char* pc = new char('c')l

2、C++中的命名空间

在C语言中只有一个全局作用域

  • C语言所有的全局标识符共享同一个作用域
  • 标识符之间可能发生冲突

C++中提出了命名空间的概念

  • 命名空间将全局作用域分成不同的部分
  • 不同命名空间中的标识符可以同名而不会发生冲突
  • 命名空间可以相互嵌套
  • 全局作用域也叫默认命名空间

定义:

namespace Name
{
  namespace Internal
  {
    /* ... */
  }
  /* ... */
}

命名空间的使用

using namespace name;   // 使用整个命名空间
using name::variable;   // 使用命名空间中的变量
::variable;        // 使用默认命名空间中的变量
#include <stdio.h>

namespace First
{
  int i = 0;
}

namespace Second
{
  int i = 1;
  
  namespace Internal
  {
    struct P
    {
      int x;
      int y;
    };
  }
}

int main()
{
  using namespace First;
  using Second::Internal::P;
  
  printf("First::i = %d\n", i);
  printf("Second::i = %d\n", Second::i);
  
  P p = {2, 3};
  
  printf("p.x = %d\n", p.x);
  printf("p.y = %d\n", p.y);
  
  return 0;
}

命名空间解决了全局变量命名冲突的问题

3、小结

C++ 中内置了动态内存分配的专用关键字

C++ 中的动态内存分配可以同时进行初始化

C++ 中的动态内存分配时基于类型进行的

C++ 中命名空间概念用于解决名称冲突问题

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

用标准c++实现string与各种类型之间的转换

这个类在头文件中定义, < sstream>库定义了三种类:istringstream、ostringstream和stringstream,分别用来进行流的输入、输出和输入输出操作。另外,每个类都有一个对应的宽字符集版本
收藏 0 赞 0 分享

C++如何通过ostringstream实现任意类型转string

再使用整型转string的时候感觉有点棘手,因为itoa不是标准C里面的,而且即便是有itoa,其他类型转string不是很方便。后来去网上找了一下,发现有一个好方法
收藏 0 赞 0 分享

C/C++指针小结

要搞清一个指针需要搞清指针的四方面的内容:指针的类型,指针所指向的类型,指针的值或者叫指针所指向的内存区,还有指针本身所占据的内存区
收藏 0 赞 0 分享

C++ 类的静态成员深入解析

在C++中类的静态成员变量和静态成员函数是个容易出错的地方,本文先通过几个例子来总结静态成员变量和成员函数使用规则,再给出一个实例来加深印象
收藏 0 赞 0 分享

C++类的静态成员初始化详细讲解

通常静态数据成员在类声明中声明,在包含类方法的文件中初始化.初始化时使用作用域操作符来指出静态成员所属的类.但如果静态成员是整型或是枚举型const,则可以在类声明中初始化
收藏 0 赞 0 分享

C++类静态成员与类静态成员函数详解

静态成员不可在类体内进行赋值,因为它是被所有该类的对象所共享的。你在一个对象里给它赋值,其他对象里的该成员也会发生变化。为了避免混乱,所以不可在类体内进行赋值
收藏 0 赞 0 分享

C++中的friend友元函数详细解析

友元可以是一个函数,该函数被称为友元函数;友元也可以是一个类,该类被称为友元类。友元函数的特点是能够访问类中的私有成员的非成员函数。友元函数从语法上看,它与普通函数一样,即在定义上和调用上与普通函数一样
收藏 0 赞 0 分享

static全局变量与普通的全局变量的区别详细解析

以下是对static全局变量与普通的全局变量的区别进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
收藏 0 赞 0 分享

C++ explicit关键字的应用方法详细讲解

C++ explicit关键字用来修饰类的构造函数,表明该构造函数是显式的,既然有"显式"那么必然就有"隐式",那么什么是显示而什么又是隐式的呢?下面就让我们一起来看看这方面的知识吧
收藏 0 赞 0 分享

教你5分钟轻松搞定内存字节对齐

随便google一下,人家就可以跟你解释的,一大堆的道理,我们没怎么多时间,讨论为何要对齐.直入主题,怎么判断内存对齐规则,sizeof的结果怎么来的,请牢记以下3条原则
收藏 0 赞 0 分享
查看更多