1.申明和初始化指针
int * p1;
这表明 *p1的类型为int 。由于*操作符被用于指针,因此p1变量本身必须是指针。可以这样说,p1是指针(也即是地址空间),*p1是int,而不是指针;
顺便说一下,*操作符两边的空格是可选的.传统上c程序员用int *p1,而很多c++程序员用int* p1;
可以在申明语句中初始化指针,在这种情况下,被初始化的是指针,而不是它所指向的值.也就是说下面的语句:
int p1=5;
int *pt=&p1;
将pt(而不是*pt)的值设置为&p1.
2.指针的危险
极其重要的一点:在c++中创建指针时,计算机将分配用来存储地址的内存,但不会分配用来存储指针所指向的数据的内存.为数据提供空间是一个独立的过程,忽略这一步无疑是自找麻烦:
int *p1;
*p1=12;
p1确实是一个指针,但他指向那里呢,上叙代码并没有将地址赋给p1,那么12将被放在哪里呢,我们不知道.
警告:一定要在对指针应用解除引用操作符*之前,将指针初始化为一个确定的适当的地址.这是关于使用指针的金科玉律.
3.用new来分配内存
指针真正的用武之地在于,在运行阶段分配未命名的内存以存储值,在这种情况下只能用指针来访问内存.
下面是这样的一个范例:
int *p1=new int;
*p1=1000;
数组:
int *p1=new int[10];
p1代表的是地址,而*p1则代表一个值;
对于数组p1来讲,new操作符返回第一个元素的地址,在这个例子中,该地址被赋给指针p1;
计算机可能会由于没有足够的内存而无法满足new的请求,在这种情况下,new将返回0;
4.用delete来释放内存
delete操作符,他使得在用完内存后,能够将其归还给内存池,这是通向最有效的使用内存的的关键的一步
int *ps = new int;
...
delete ps;
这将释放ps指向的内存,但不会删除指针ps本身,也就意味着可以将指针ps重新指向另外一个新分配的内存块;
注意:一定要配对的使用new和delete,否则将发生内存泄露,也就是说被分配的内存再也无法使用了.
int *p1=new int[10];
...
delete [] p1;
5.指针与数组
#include<iostream.h>
int main()
{
double *p3 =new double [3];
p3[0]=0.2;
p3[1]=0.3;
p3[2]=0.5;
cout<<"p3[1] is "<<p3[1]<<endl;
p3=p3+1;
cout<<"now p3[0] is "<<p3[0]<<endl;
p3=p3-1;
delete [] p3;
return 0;
}
{
double *p3 =new double [3];
p3[0]=0.2;
p3[1]=0.3;
p3[2]=0.5;
cout<<"p3[1] is "<<p3[1]<<endl;
p3=p3+1;
cout<<"now p3[0] is "<<p3[0]<<endl;
p3=p3-1;
delete [] p3;
return 0;
}
下面是程序的输出:
p3[1] is 0.3
now p3[0] is 0.3
now p3[0] is 0.3
最后一个程序用VC6.0程序会崩溃的
回复删除