首先声明,我是一个菜鸟。一下文章中出现技术误导情况盖不负责
先看 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
指针和限定符
---------------------------------