700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > 自定义数据类型的指针的含义

自定义数据类型的指针的含义

时间:2019-09-25 19:39:29

相关推荐

自定义数据类型的指针的含义

指针的难点在于它既可以操作指向的数据本身,又可以操作该数据的地址。

书本上对指针的介绍都是从最简单的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中的内容,这就是自定义数据类型的指针与系统数据类型的指针的不同

(我还只是个初学者,第一次尝试写博客也是听从了一些大佬的建议,帮助学习,如有任何不对的地方欢迎批评指正。)

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。