C++中指针的运用十分频繁,且极其容易出错,一旦出现引用空指针或指针未释放都可能引起程序的bug。其中,指针的指针这一概念更是不好理解,在这里记录一下指针一些问题的测试,便于将来查阅。
- 测试1
- 测试2
测试1
首先定义一个void型指针p,将指针指向NULL:
void *p = NULL;
接着定义一个指针的指针pp,指向指针p:
void *pp = &p;
于是,这里可以看出指针p的值应该为其指向的变量NULL的地址,由于此时p为空指针,因此若使用*p这会使得编译环境报错,因为使用了空指针;同理,此时指针pp的值为变量p的地址,而 *pp为变量p的值,应该为NULL,如下语句测试:
cout << "p " << p << " " << "pp " << pp << endl;
cout << "*pp " << *pp << endl;
结果如下:
p 00000000 pp 00F7FC1C
*pp 00000000
可以看出,虽然p变量指向NULL,但是p的地址值是实际存在的。
测试2
定义一个结构体:
typedef struct _TEST_Y_{
int c;
int a;
string b;
}TEST, *PTEST;
然后,定义一个指针pHandle:
void *pHandle = NULL;
接着为改指针分配内存:
pHandle = (void*)malloc(sizeof(TEST));
PTEST pTest = (PTEST)pHandle;
这里,为指针pHandle分配内存是必须的,如果没有为pHandle分配内存,直接将pTest指向pHandle指向的位置,那么pTest讲也是NULL,这时对pTest作如下操作就会出现异常:
pTest->a = 10;
pTest->c = 100;
然而,在对pHandle指针分配内存之后上面两行代码已经没有问题了,但是对变量b的赋值依然存在问题:
pTest->b = "ssss";
这样,就会出现异常;
如果,修改TEST结构体的定义,把成员变量b改为一个数组变量,如下:
#define MAX 10
typedef struct _TEST_Y_{
int c;
int a;
int b[MAX];
}TEST, *PTEST;
然后,对b的赋值如下:
pTest->b[5] = 1;
这样就不会报错,这是什么原因呢?
其实,是因为当结构体变量中成员量b为string类型时,由于string是一个类,而在对类的变量赋值时应该调用类的构造函数,而直接将”ssss”赋值给b没有调用这个过程,因此就会报错;那么这个问题该如何解决:1、采用new的方法新建TEST变量;2、使用 placement new 操作符,但是貌似比较复杂,不介绍…(因为我也没细看-_-||)