C语言是计算机软件领域最为经典的编程语言之一,尤其在底层驱动、硬件控制等应用领域,更是C语言的价值所在,这是JAVA,C#等新兴高级语言所不具备的优势所在,通过C语言的指针操作系统内存,以及位运算控制系统的各个外部I/O端口,C语言被广泛应用到硬件系统的控制中,指针的应用是C语言的灵魂,指针实现了C语言的灵活性、可变性。以下对C语言中指针的应用与价值进行探讨与阐述。
C语言编程过程中,假设定义一个变量,编译时就为这个变量分配一定长度的内存空间。而在内存区每一个内存单元都有一个地址,用来标识内存单元,在地址所标识的单元存放数据。而正确使用指针变量,区分指针变量和指针的指向变量的含义和用法,判断变量与运算符的结合顺序来确定变量的数据类型以及指向变量或成员变量的类型。通过指针来访问数组元素和下标法数组元素的等价关系,作为函数参数的指针变量,可以改变所指向的主调函数变量的值。动态存储分配、对链表的创建以及相关操作都可以运用指针实现。
类成员的指针,类成员与外部变量相互比较,进行区分的方法就是它所在的域的不同,因为域的不同而决定了变量可以使用的范围,一个指向类的成员函数或者成员变量的指针,就要规范它的参数列表、返回类型,以及被指向变量或函数的域,所以使用类域限定如下:
classNJUPT{ staticdoublenumber=20000000; intnum; public: NJUPT():num(10){}; intget(){returnnum;}; doublegetNumber(){reuturnnumber;}}
在这里定义的成员指针为intNJUPT::*p;//指向int型成员变量int(NJUPt::*)p()//指向intf()型成员函数。
那么调用的方式为&#xff1a;cout<&#xff1b;
返回指针的函数&#xff0c;一个函数的接口是它的返回值&#xff0c;C语言可以自定义类型&#xff0c;我们使用引用作为函数的实际参数&#xff0c;或在函数的实际参数中使用指针。使用一个函数返回一个指针很容易将一个局部变量的地址传出来。例如&#xff1a;
UserType*Process(){ UserTypeut(param—list)&#xff1b; //processut&#xff1b; return&&#xff1b;ut&#xff1b;//}
变量在函数运行结束已经被销毁&#xff0c;被传出的地址实际已经不存在被释放了。所以很容易出错。另一点是在运用new的时候。易造成内存泄露。
UserType*Process(){ UserTpye*put&#61;newUserType(param—list)&#xff1b; //processput&#xff1b; returnput&#xff1b;}
在函数内部使用一个new&#xff0c;分配了一个空间传出来。这样就不会发生问题&#xff0c;只是编程过程中通常会忘记在程序的外面把借来的空间还回去而造成内存泄露&#xff0c;所以把函数的参数设定为指针或引用作为代替。
两指针变量相减&#xff1a;所得之差是两个指针所指数组元素之间相差的元素个数。实际上是两个指针值(地址)相减之差再除以该数组元素的长度(字节数)。例如pf1和pf2是指向同一浮点数组的两个指针变量&#xff0c;设pf1的值为2010H&#xff0c;pf2的值为2000H&#xff0c;而浮点数组每个元素占4个字节&#xff0c;所以pf1—pf2的结果为(2000H—2010H)/4&#61;4&#xff0c;表示pf1和pf2之间相差4个元素。两个指针变量不能进行加法运算。例如&#xff0c;pf1&#43;pf2是什么意思呢&#xff1f;毫无实际意义。
this指针的用处&#xff1a;一个对象的this指针并不是对象本身的一部分&#xff0c;不会影响sizeof(对象)的结果。this作用域是在类内部&#xff0c;当在类的非静态成员函数中访问类的非静态成员的时候&#xff0c;编译器会自动将对象本身的地址作为一个隐含参数传递给函数。也就是说&#xff0c;即使你没有写上this指针&#xff0c;编译器在编译的时候也是加上this的&#xff0c;它作为非静态成员函数的隐含形参&#xff0c;对各成员的访问均通过this进行。例如&#xff1a;调用date.SetMonth(9)SetMonth(&date&#xff0c;9)&#xff0c;this帮助完成了这一转换.
以上是学习指针过程中个人总结出来的观点和方法&#xff0c;希望初学C语言或对指针有迷惑的人给予帮助&#xff0c;以便更好的学好指针、掌握C语言的精髓。