本文主要是介绍C语言中的“倚天剑”--谈指针的几点见解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
昨天回顾了一下C语言的指针这一部分,每一次重新回顾,总能够再次发现一些新的东西,在C的积淀里又能够获得一些收获和提升。
下面针对这一部分,写一些自己的心得,没有做任何的梳理,写到哪里算哪里吧,望看过该篇的朋友见谅!*_*
就在前几个月还不理解为什么C要有指针这个东西,并且指针在C语言开发乃至底层开发的过程中所发挥的无与伦比的作用,现在看看,何止是无与伦比,指针简直就是C语言的灵魂,不学指针,或者没有学好指针,就可以说不会C语言的编程,那么,这样说来,我本科阶段基本不会C语言了。。。&_&
定义一个变量,可以这样写 int a; //a是什么?其实a是编程语言里的东西,是针对用户与开发人员的,是可以看得见的东西,但是在计算机底层或者硬件结构中,是没有变量a这个东西的,那是什么东西呢?是一个确定的地址,比如0x10,在内存中就只有一个地址为0x10的地址与变量a对应,因为计算机知道,变量a是它在编程语言中的身份,而在内存中,对应的就是地址0x10了。
指针的作用发挥在哪里呢?我想了一下,它是作用主要是体现在能够在编程语言的框架下,任意修改一块确定内存里的数据,举个简单的实例,交换两个数的大小,大致代码如下:
int swap(int *p1,int *p2)
{
int temp;
temp = *p1;*p1 = *p2; *p2 = temp;
}
int main()
{
int a=1.b=2;
printf("a=%d,b=%d\n",a,b);
swap(&a,&b);
printf(""a=%d,b=%d\n",a,b");
return 0;
}
想想上面函数参数里的形参即指针变量,如果swap()函数里传的不是指针变量,而是普通变量,还可以这样去修改a b的值吗?
答案一定是否定的,最起码不会很便捷。这只是在函数与函数之间的操作,用传地址的方式来修改两个变量的值,而底层接口都是基于C开发的,大量的接口肯定需要用到各种数据或值的修改,如果用指针做操作,一定是底层开发程序猿们最惬意的帮手。
指针就好像武侠世界里的"倚天剑",能够披荆斩棘,所向披靡,凡是指针可以指向的内存地址,都是可以修改该地址对应的内容的。
但是问题就来了,是不是所有的指针执行的内存地址都是合法有效的呢?
就好像倚天剑虽然厉害,但是难免会伤及无辜,所以也就有了"野指针"的说法。以前不知道什么是野指针,虽然也见过,只闻其声,不知其意。现在看差不多就懂是什么意思了
看如下代码:
int func()
{
char *p = (char*)malloc(1);
char a;
p = &a;
*p = 'a';
free(p);//此时的p如果再次使用,就嫣然是一个野指针了
}
野指针的意思是它指向的地址不知道是否是合法的,如果恰巧是合法的,那么编译器也通过了,如果不是合法的,那么就直接编译出错了。
所以野指针一定要避免,防患于未然。
而一个好的C开发工程师一定是要非常小心的使用指针,并且也是熟练的操作指针的。
这篇关于C语言中的“倚天剑”--谈指针的几点见解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!