new动态申请的内存 和直接定义的数组 在内存的处理上一样吗
int*b=newint[10]和intb[10]还有int*b内存的处理上一样吗?在调用函数中动态申请的int*b=newint[10],内存附初值后,第二次调用时还可...
int *b=new int[10] 和int b[10]还有int*b内存的处理上一样吗? 在调用函数中动态申请的int *b=new int[10] ,内存附初值后,第二次调用时还可以用吗?直接用b这个指针可以吗?会回收吗?
展开
3个回答
展开全部
//用法和解释全在下面了,每条语句都仔细看一遍,以后就不会再问类似问题了
#include<iostream>
using namespace std;
int main( )
{
int a[10]; //a有内存空间
int* p; //p还没有内存空间
cout<<hex<<a<<endl; //看看a的内存地址
cout<<hex<<p<<endl; //看看p的内存地址,无效的,取*p就会崩溃
p=&a[0];
cout<<hex<<p<<endl; //看看p的内存地址,会发现就是a的地址
//delete p; //初始收回p的内存地址就会崩溃,非动态分配的
p=new int[10];
cout<<hex<<p<<endl; //看看p的内存地址
delete p; //收回它
p=new int[20];
cout<<hex<<p<<endl; //看看p的内存地址
delete p; //收回它
p=new int[30];
cout<<hex<<p<<endl; //看看p的内存地址
p=&a[0]; //这时候p就会改变指向,所以分配的30已经丢了
//delete p; //收回它,已经丢了,就会崩溃
//所以要动态分配的内存的指针,最好加const
int* const q=new int[40]; //指针q不能改变,*q随意写数据,这样丢不掉,delete不会出错
(*q)++; //对
//*q++; //错了
p=q; //用随意修改的指针p来操作内存空间,q不要动
(*p)++; //对
*p++; //对
delete q; //收回q
return 0;
}
#include<iostream>
using namespace std;
int main( )
{
int a[10]; //a有内存空间
int* p; //p还没有内存空间
cout<<hex<<a<<endl; //看看a的内存地址
cout<<hex<<p<<endl; //看看p的内存地址,无效的,取*p就会崩溃
p=&a[0];
cout<<hex<<p<<endl; //看看p的内存地址,会发现就是a的地址
//delete p; //初始收回p的内存地址就会崩溃,非动态分配的
p=new int[10];
cout<<hex<<p<<endl; //看看p的内存地址
delete p; //收回它
p=new int[20];
cout<<hex<<p<<endl; //看看p的内存地址
delete p; //收回它
p=new int[30];
cout<<hex<<p<<endl; //看看p的内存地址
p=&a[0]; //这时候p就会改变指向,所以分配的30已经丢了
//delete p; //收回它,已经丢了,就会崩溃
//所以要动态分配的内存的指针,最好加const
int* const q=new int[40]; //指针q不能改变,*q随意写数据,这样丢不掉,delete不会出错
(*q)++; //对
//*q++; //错了
p=q; //用随意修改的指针p来操作内存空间,q不要动
(*p)++; //对
*p++; //对
delete q; //收回q
return 0;
}
展开全部
数组其实也是一种指针,只是这种指针系统已经为他分配好了内存地址,在变量周期结束的时候也会自动回收。指针的话int *p系统是不会为p分配内存的,这时候p就是一个野指针,你可以p=new int[10]来为它分配内存,注意要用delete回收,要不然会出现内存泄露。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
一般的“短命”(运行后很快就结束)程序就不要考虑自动分配大小,如果你要编写长期运行的程序那就一定要考虑这些了。
所谓动态大小的数组,实际上是用指针来实现的,我们只需要定义:
int *a;
int n,i;
获取需要的大小之后,比如:
scanf("%d",&n);
申请需要的内存空间:
a=malloc(n*sizeof(int));
这以后就可以使用数组a[0]~a[n-1]了,比如:
for (i=0;i<n;i++) scanf("%d",&a[i]);
所谓动态大小的数组,实际上是用指针来实现的,我们只需要定义:
int *a;
int n,i;
获取需要的大小之后,比如:
scanf("%d",&n);
申请需要的内存空间:
a=malloc(n*sizeof(int));
这以后就可以使用数组a[0]~a[n-1]了,比如:
for (i=0;i<n;i++) scanf("%d",&a[i]);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询