首先声明,我是一个菜鸟。一下文章中出现技术误导情况盖不负责
先看 const int a = 2; a的值是只读。
const int * p 与 int * const p 的 区分 ,。
可以这样懂得:以*为分界点把变量分成两部分, 看const修饰谁。
const int * p:const 修饰的是int 所以 把const int 看成是一种类型,很显然 这种类型的内存是只读的。p指针本身不是只读
int * const p:const 修饰的是p,和下面的a一样是只读的,指向的内存并非只读的,是读写的。
另外const int * p 和int const * p 写法是一样的。
例子:
#include <stdio.h>
static const int num = 5;
static int a[5] = {0,1,2,3,4};
extern void print_all_address_value(const int p[], const int p1[] );//这种参数的好处是,数据在访问过程当中不会被变动。。
extern int get_value(const int * const a);//这种参数的好处是,数据在访问过程当中不会被变动,还有保障了获取到所需的数据,而不是意外的数据。
extern int set_value(int * const a, const int value);//这种参数的好处是,保障变动的数据,的确是我们需要变动的。
每日一道理
天又快黑了,这座忙碌的城市又将入睡,让这劳累的“身躯”暂别白日的辛勤,让它入睡,陪伴着城市中的人们进入梦乡。当空的弯月正深情地注视着这座城市与城市中的人们,看着家家户户的灯渐渐熄灭,它在床头悄悄奏响“明月曲”……
天又快黑了,这座忙碌的城市又将入睡,让这劳累的“身躯”暂别白日的辛勤,让它入睡,陪伴着城市中的人们进入梦乡。当空的弯月正深情地注视着这座城市与城市中的人们,看着家家户户的灯渐渐熄灭,它在床头悄悄奏响“明月曲”……
void main(){
int *p, *p1 ;
p = a;
p1 = &a[0];
print_all_address_value(p,p1);
set_value(p+1,9);
get_value(p1+1);
printf("value p1 = %d\n",get_value(p+1));
}
extern void print_all_address_value(const int p[], const int p1[] ){
int i = 0;
for(i=0;i<num;i++){
printf("for address a = %p, p = %p, p1 = %p\n", &a[i],p,p1);
printf("for value a = %d, p = %d, p1 = %d\n", a[i],*p,*p1);
p++;
p1++;
}
}
extern int get_value(const int * const a){
return *a;
}
extern int set_value(int * const a, const int value){
*a = value;
return *a;
}
文章结束给大家分享下程序员的一些笑话语录: 女人篇
有的女人就是Windows虽然很优秀,但是安全隐患太大。
有的女人就是MFC她条件很好,然而不是谁都能玩的起。
有的女人就是C#长的很漂亮,但是家务活不行。
有的女人就是C++,她会默默的为你做很多的事情。
有的女人就是汇编虽然很麻烦,但是有的时候还得求它。
有的女人就是SQL,她会为你的发展带来莫大的帮助。
--------------------------------- 原创文章 By
指针和限定符
---------------------------------