最近在用指针,所以将有关指针的&和*的问题总结一下。
首先介绍一下指针。指针是指指向的地址,指针本身只占有4个字节,例如:
char *pt,sizeof(pt)=4,不论指针的值是什么或者它所指向的类型是什么,它
的空间分配只占有4个字节,但是sizeof(char *)=1。在这里补充一下C语言的基
本类型:
(一)32位平台:分为有符号型与无符号型。
有符号型:
short 在内存中占两个字节,范围为-2^15~(2^15-1)
int 在内存中占四个字节,范围为-2^31~(2^31-1)
long在内存中占四个字节,范围为-2^31~2^31-1
无符号型:(略)
实型变量: 分单精度 float 和双精度 double 两种形式:
float:占四个字节,提供7~8位有效数字。
double: 占八个字节,提供15~16位有效数字。
(二)16位平台:
1)整型(基本型):类型说明符为int,在内存中占2个字节。
2)短整型:类型说明符为short int或short。所占字节和取值范围均与整型(基本
型)相同。
3)长整型:类型说明符为long int或long,在内存中占4个字节。
无符号型:类型说明符为unsigned。 无符号型又可与上述三种类型匹配而构成:
各种无符号类型量所占的内存空间字节数与相应的有符号类型量相同。但由于省
去了符号位,故不能表示负数。
实型变量: 分为单精度(float型)、双精度(double型)和长双精度(long
double型)三类。
单精度型占4个字节(32位)内存空间,其数值范围为3.4E-38~3.4E+38,只能提
供七位有效数字。
双精度型占8 个字节(64位)内存空间,其数值范围为1.7E-308~1.7E+308,可
提供16位有效数字。
长双精度型16 个字节(128位)内存空间,可提供18-19位有效数字。
这里的&是取地址运算符,顾名思义就是得到地址。*书上叫间接运算符。&a
的运算结果是一个指针,指针的类型是a的类型加个*,指针所指向的类型是a的类
型,指针所指向的地址就是a的地址。*p的运算结果就是p所指向的东西,他的类
型是p指向的类型,它所占用的俄地址是p所指向的地址。
首先,*是指指针的类型(可能说的不对,大家见谅)eg.char *a是指a指针
指向的char类型.其次,&是指地址。eg.&a指的是指向a的地址。
eg.int a=12;//变量a是int型,它的值为12
int *p;//p是指向int型的指针
int **pt;//pt是指向指针的指针
p=&a;//&a是个指针,因为指针是指指向的地址,&a也表示指向的地址。
*p=12;//指变量*p的值为12,p是一个指针,*p就是一个变量。
&&a;//指指向指针的指针
pt=&p//&p的结果是个指针,该指针的类型是p的类型加个*,在这里是int**,
该指针所指向的类型是p的类型,这里是int*。该指针所指向的地址就是指针p自
己的地址。
*pt=&b;//pt已经是指向指针的指针,其前再加*则会变为指针pt(解释:按
我个人的理解就是给前面加*则级别会下降,而给前面加&级别会上升。举个例子
就是int **a,a即为指向指针的指针,*a则指指针,**a则是指一个变量;int
b,b是一个变量,&b则是指一个指针,&&b则是指向指针的指针。)