博客
关于我
C语言指针(二重指针)
阅读量:686 次
发布时间:2019-03-17

本文共 1365 字,大约阅读时间需要 4 分钟。

1.二重指针

1.1、二重指针与普通一重指针的区别

(1)本质上来说,二重指针和一重指针的本质都是指针变量,指针变量的本质就是变量。
(2)一重指针变量和二重指针变量本身都占4字节内存空间,
1.2、二重指针的本质
(1)二重指针本质上也是指针变量,和普通指针的差别就是它指向的变量类型必须是个一重指针。二重指针其实也是一种数据类型,编译器在编译时会根据二重指针的数据类型来做静态类型检查,一旦发现运算时数据类型不匹配编译器就会报错。
(2)C语言中如果没有二重指针行不行?其实是可以的。一重指针完全可以做二重指针做的事情,之所以要发明二重指针(函数指针、数组指针),就是为了让编译器了解这个指针被定义时定义它的程序员希望这个指针被用来指向什么东西(定义指针时用数据类型来标记,譬如int *p,就表示p要指向int型数据),编译器知道指针类型之后可以帮我们做静态类型检查。编译器的这种静态类型检查可以辅助程序员发现一些隐含性的编程错误,这是C语言给程序员提供的一种编译时的查错机制。
(3)为什么C语言需要发明二重指针?原因和发明函数指针、数组指针、结构体指针等一样的。
练习题目:二重指针和一重指针的使用

/*	char a;		char **p1;		// 二重指针	char *p2;		// 一重指针		printf("sizeof(p1) = %d.\n", sizeof(p1));   //=4	printf("sizeof(p2) = %d.\n", sizeof(p2));   //=4		p2 = &a;	//p1 = &a;		//error	因为两者类型不一样	                // p1是char **类型,&a是char *类型。					// char **类型就是指针指向的变量是char *类型					// char *类型表示指针指向的变量是char类型。	p1 = &p2;		// p2本身是char *类型,再取地址变成char **类型,和p1兼容。*/

1.3、二重指针的用法

(1)二重指针指向一重指针的地址
(2)二重指针指向指针数组的

/*		int *p1[5];	int *p2;	int **p3;		//p2 = p1;   	//error,类型不一致	p3 = p1;		// p1是指针数组名,本质上是数组名,数组名做右值表示数组首元素					   首地址。数组的元素就是int *类型,所以p1做右值就表示一个int *					   类型变量的地址,所以p1就是一个int类型变量的指针的指针,所以					   它就是一个二重指针int **;*/

(3)实践编程中二重指针用的比较少,大部分时候就是和指针数组纠结起来用的。

(4)实践编程中有时在函数传参时为了通过函数内部改变外部的一个指针变量,会传这个指针变量的地址(也就是二重指针)进去

1.4、二重指针与数组指针

(1)二重指针、数组指针、结构体指针、一重指针、普通变量的本质都是相同的,都是变量。
(2)所有的指针变量本质都是相同的,都是4个字节,都是用来指向别的东西的,不同类型的指针变量只是可以指向的(编译器允许你指向的)变量类型不同。
(3)二重指针就是:指针数组指针

转载地址:http://vyvhz.baihongyu.com/

你可能感兴趣的文章
Mysql InnoDB存储引擎中的checkpoint技术
查看>>
Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql innodb通过使用mvcc来实现可重复读
查看>>
mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
MySQL Join算法与调优白皮书(二)
查看>>
Mysql order by与limit混用陷阱
查看>>
Mysql order by与limit混用陷阱
查看>>
mysql order by多个字段排序
查看>>
MySQL Order By实现原理分析和Filesort优化
查看>>
mysql problems
查看>>
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql replace用法
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>