C++中指针和内存分配的方法-创新互联
这篇文章主要介绍“C++中指针和内存分配的方法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“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关键字释放该内存空间。
动态内存分配概念的主要用途是通过指定其大小来声明数组,但不确定它时将内存分配给数组。
看一个例子来理解数组的内存分配用法。
#includeusing 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++中指针和内存分配的方法-创新互联
本文来源:http://ybzwz.com/article/ijodg.html