linux 中的指针

来源:互联网 发布:pkpm节能软件 编辑:程序博客网 时间:2024/06/15 11:00

1.指针的算数运算与关系运算是如何实现的?

第一种形式是:指针+-整数 标准定义这种形式只能用于指向数组中某个元素的指针,并且这类表达式的结果类型也是指针。这种形式也适用于使用malloc函数动态分配获得的内存。

对一个指针加1使它指向数组中的下一个元素,加5使它向右移动5个元素的位置,依次类推。把一个指针减去3使它向左移动3个元素的位置。


第二种类型的指针运算具有如下的形式:指针—指针

只有当两个指针都指向同一个数组中的元素时,才允许从一个指针减去另一个指针, 两个指针相减的结果的类型是ptrdiff_t,它是一种有符合整数类型。减法运算的值是两个指针在内存中的距离是指针的本身(以数组元素的长度为单位,而不是以字节为单位),因为减法运算的结果将除以数组元素类型的长度。

只有当两个指针指向同一个数组中的元素时,才能进行关系运算。 
当指针p和指针q指向同一数组中的元素时, 
则: (可以用在if判断里面作为条件)

p<q 当p所指的元素在q所指的元素之前时,表达式的值为1;反之为0。 
P>q 当p所指的元素在q所指的元素之后时,表达式的值为1;反之为0。 
p==q 当p和q指向同一元素时,表达式的值为1;反之为0。 
p!=q 当p和q不指向同一元素时,表达式的值为1;反之为0。

2.sizeof与strlen的区别

一、sizeof
    sizeof(...)是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可以是数组、指针、类型、对象、函数等。
    它的功能是:获得保证能容纳实现所建立的最大对象的字节大小。
    由于在编译时计算,因此sizeof不能用来返回动态分配的内存空间的大小。实际上,用sizeof来返回类型以及静态分配的对象、结构或数组所占的空间,返回值跟对象、结构、数组所存储的内容没有关系。
    具体而言,当参数分别如下时,sizeof返回的值表示的含义如下:
    数组——编译时分配的数组空间大小;
    指针——存储该指针所用的空间大小(存储该指针的地址的长度,是长整型,应该为4);
    类型——该类型所占的空间大小;
    对象——对象的实际占用空间大小;
    函数——函数的返回类型所占的空间大小。函数的返回类型不能是void。

3.空指针有哪几种用法?

1) 用空指针终止对递归数据结构的间接引用,递归是指一个事物由这个事物本身来定义。

2) 用空指针进行函数调用失败时的返回值。

3) 用空指针作警戒值.


4.const关键字的特点是什么?

const:修饰一个只读变量。 如 const int cc=3   cc是只读变量。只能说明,不能通过cc这个变量去修改它对应内存空间的值。

const int *p         地址p指向的内容不可改变

int * const p        地址p不可改变

const int * const p   地址p和地址p指向的内容两者皆不可改变

 

原因是const 有就近原则,靠近谁就限制谁。


5.指针的类型是什么 ?

从语法的角度看,你只要把指针声明语句里的指针名字去掉,剩下的部

分就是这个指针的类型。这是指针本身所具有的类型。

例:

(1)int*ptr; //指针的类型是int*

(2)char*ptr; //指针的类型是char*

(3)int**ptr; //指针的类型是int**

(4)int(*ptr)[3]; //指针的类型是int(*)[3]

(5)int*(*ptr)[4]; //指针的类型是int*(*)[4]

6.

指针数组和数组指针的区别

数组指针(也称行指针)
定义 int (*p)[n];
()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。

如要将二维数组赋给一指针,应这样赋值:
int a[3][4];
int (*p)[4]; //该语句是定义一个数组指针,指向含4个元素的一维数组。
p=a; //将该二维数组的首地址赋给p,也就是a[0]或&a[0][0]
p++; //该语句执行过后,也就是p=p+1;p跨过行a[0][]指向了行a[1][]

所以数组指针也称指向一维数组的指针,亦称行指针。

指针数组
定义 int *p[n];
[]优先级高,先与p结合成为一个数组,再由int*说明这是一个整型指针数组,它有n个指针类型的数组元素。这里执行p+1时,则p指向下一个数组元素,这样赋值是错误的:p=a;因为p是个不可知的表示,只存在p[0]、p[1]、p[2]...p[n-1],而且它们分别是指针变量可以用来存放变量地址。但可以这样*p=a; 这里*p表示指针数组第一个元素的值,a的首地址的值。
如要将二维数组赋给一指针数组:
int *p[3];
int a[3][4];
p++; //该语句表示p数组指向下一个数组元素。注:此数组每一个元素都是一个指针
for(i=0;i<3;i++)
p[i]=a[i]
这里int *p[3] 表示一个一维数组内存放着三个指针变量,分别是p[0]、p[1]、p[2]

这样两者的区别就豁然开朗了,数组指针只是一个指针变量,似乎是C语言里专门用来指向二维数组的,它占有内存中一个指针的存储空间。指针数组是多个指针变量,以数组形式存在内存当中,占有多个指针的存储空间。

7.右左法则是通用的吗 
右左法则是一个既著名又常用的方法,不过,右左法则其实并不是C标准里面的内容,它是从C标准的声明规定中归纳出来的。C标准的声明规则,是用来解决如何创建声明的,而右左法则是用来解决如何辨识一个声明的,两者可以说是相反的。



原创粉丝点击