C++ 第十课 C++中的新成员 ---- (狄泰软件学院)

动态内存分配

C++中的动态内存分配

C++中通过 new 关键字 进行 动态内存申请

C++中的动态内存申请是基于类型进行的

delete 关键字用于内存释放

C++ 第十课 C++中的新成员 ---- (狄泰软件学院)_第1张图片

实例分析:C++中的动态内存分配 10-1

#include 

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];
    
    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');

 

编程实验 10-2 初始化动态内存

#include 

int main()
{
    int* pi = new int(1);
    // int* pa = new int[1];
    
    float* pf = new float(2.0f);
    char* pc = new char('c');

    printf("*pi = %d\n", *pi);
    printf("*pf = %f\n", *pf);
    printf("*pc = %c\n", *pc);
    
    delete pi;
    delete pf;
    delete pc;
    
    return 0;
}

C++中的命名空间

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

C语言中所有的全局标识符共享同一个作用域

标示符之间可能发生冲突

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

命名空间将全局作用域分成不同的部分

不同命名空间中的标识符可以同名而不会发生冲突

命名空间可以相互嵌套

全局作用域也叫默认命名空间

C++ 第十课 C++中的新成员 ---- (狄泰软件学院)_第2张图片

C++命名空间的使用

使用整个命名空间: using namespace name;

使用命名空间中的变量:using name::variable;

使用默认命名空间中的变量: ::variable

 

实例分析: 命名空间的使用 10-3

#include 

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;
}

小结:

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

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

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

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

 

 

你可能感兴趣的:(C学习(狄泰软件学院),c++)