指针的难点在于它既可以操作指向的数据本身,又可以操作该数据的地址。
书本上对指针的介绍都是从最简单的int类型的指针开始讲解,最近刚开始学习数据结构,被指针绕的晕乎乎的。但是我发现其实最难的就在于指针,因为这与书本上最简单的指针并不一样:
int类型的指针:
定义的时候可以写成这样:
int * p; 或 int * p = 0; 或 int * p = &a;
但是如果把定义和初始化分开写:
int * p;
p = &a; 或 p = NULL;
定义的时候要把 int* 放一起,p就是指针,可以给他赋值地址;使用的时候 单独一个 p 是指针,而*p是取地址。
自定义数据类型的指针:
在链表中会定义一个Node类型的结构体:
struct Node{int data;Node* next;};
第一个是数据域,用于存储数据,第二个是指针域,用于指向下一个节点。
做了一个简单的测试:
#include <iostream>using namespace std;//Node节点struct Node{int data;Node* next;};int main(){//int 类型指针 测试int a = 10;int* p;p = &a;cout << p << endl;cout << *p << endl;//Node类型指针 测试Node* p1;Node a1;a1.data = 20;a1.next = NULL;p1 = &a1;cout << p1->data << endl;cout << p1 << endl;system("pause");system("cls");}
测试结果如下:
对于int 类型的指针 p,直接输出p就是地址,而*p是取值,这很容易理解;
对于Node类型的指针p1,直接输出p1是地址,但是p1->data 却是a1->data中的内容。
也就是说,只有p1本身是地址,p1中的内容都是a1中的内容,这就是自定义数据类型的指针与系统数据类型的指针的不同
(我还只是个初学者,第一次尝试写博客也是听从了一些大佬的建议,帮助学习,如有任何不对的地方欢迎批评指正。)