一文读懂C++中指针和内存分配
指针
指针是保存内存位置地址的变量。我们知道声明的所有变量在内存中都有一个特定的地址。声明一个指针变量来指向内存中的这些地址。
声明指针变量的一般语法是:
int p, *ptr; //声明变量p和指针变量ptr
p = 4; //赋值4给变量p
ptr = &p; //将p的地址分配给指针变量ptr
在内存中,这些声明将表示如下:
这是指针在内存中的内部表示。当地址变量分配给指针变量时,它指向的变量如上图所示。
由于 ptr
具有变量 p 的地址,*ptr
将给出变量 p 的值(指针变量 ptr 指向的变量)。
为什么需要 C++ 中的指针?为了解释对指针的需要,有必要回到基本内存布局。
每当执行程序时,程序指令都会驻留在代码段中。并且所有的方法和数据都将驻留在堆栈中。代码部分只能访问堆栈部分,但不能直接访问堆部分。
注意:由于代码段不能直接访问堆段,所以不能直接使用堆内存,会被浪费掉,造成栈内存溢出。
使用指针可以解决这个问题。指针为代码部分提供了对堆内存的间接访问
在堆栈部分创建一个指针,该指针指向堆部分的内存地址,从而间接访问堆部分。
C++ 中使用指针的动态内存分配:
在堆部分分配内存发生在运行时,而不是在编译时,因此分配堆内存称为动态内存分配。
一般来说,C++不会在堆中分配一个内存,因为在使用指针时通常会遇到的复杂性。所以只分配一个内存块,我们就要使用堆内存,比如对于数组,我们会进行动态内存分配。
在 C++ 中,new
运算符用于在运行时分配内存,内存以字节为单位分配。该新操作符表示用于在堆动态存储器分配的请求。如果有足够的内存可用,则new运算符初始化内存并将新分配和初始化的内存的地址返回给指针变量。
语法:
datatype *pointer_name = new datatype
具体例子
int *ptr = new int;//在动态分配时,我们可以通过以下两种方式声明一个变量。
int *ptr = new int (10);
int *ptr = new int {15};
// new运算符还用于分配数据类型的内存块(数组)。
int *ptr = new int[20];
// 上面的语句为int类型的20个整数连续动态分配内存,并返回指向序列的第一个元素指向“ptr”指针。
一旦使用new关键字将堆内存分配给变量或类对象,我们就可以使用delete关键字释放该内存空间。
动态内存分配概念的主要用途是通过指定其大小来声明数组,但不确定它时将内存分配给数组。
看一个例子来理解数组的内存分配用法。
#include <iostream>
using namespace std;
int main()
{
int len, sum = 0;
cout << "Enter the no. of students in the class" << endl;
cin >> len;
int *marks = new int[len]; //Dynamic memory allocation
cout << "Enter the marks of each student" << endl;
for (int i = 0; i < len; i++)
{
cin >> *(marks + i);
}
for (int i = 0; i < len; i++)
{
sum += *(marks + i);
}
cout << "sum is " << sum << endl;
return 0;
}
在代码中,首先询问用户一个班级的学生人数,并将其值存储在 len 变量中。
然后声明一个整数数组,并使用此语句在内存中动态分配等于 len 变量中存储的值的空间 int *marks = new int[length];
因此它被分配了一个等于“长度*(1个整数的大小)”的空间。
以上就是C++中指针和内存分配的详细内容,更多关于C++指针内存分配的资料请关注编程网其它相关文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341