赞
踩
当需要采用C语言对两个数进行互换时,最先想到的是在程序中引入一个辅助变量进行实现,程序如下:
运行结果如下,能成功实现互换:
由于这种实现方式复用性不高,虽然能实现互换功能,但是实际使用时并不方便。要想提高程序的复用性,应使用函数实现。
此时能编译成功,运行结果如下:
可见,这并不是预期结果,可从程序执行过程对其进行分析
(1)程序从main函数开始执行,对变量a、b进行初始化,系统为变量a、b分配内存空间。
(2)程序运行到函数swap_1(a, b),此时系统为函数中的形参a、b分配内存空间(注意:函数中的a、b为形参,不同于主函数中的a、b)。函数内部对a、b进行互换,此时形参a、b发生改变。函数执行结束后,形参a、b不再存在。
(3)打印a、b值,a、b仍为main函数中的a、b。
此程序中使用指针进行互换操作,但是实际互换的只是p、q的值。程序运行时变量a、b、p、q的内容如下图所示,函数执行只是互换其中p、q的值,即将p和q中所存的值进行了互换,a、b变量值并未发生变化。
互换之前
互换之后
运行结果如下:
p是int *类型,*p是int类型,所以t为int类型。*p、*q等价于a、b,所以此程序交换的是a、b变量的值。
可见,只有通过这种方式才能真正做到实现两个数的互换。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。