又论指针

再论指针
我们都知道,如果想要通过函数改变一个变量,需要传入这个变量的指针。同样,想要改变一个指针变量,需要传入指针的指针。
 27 PRIVATE char* i2a(int val, int base, char ** ps)
 28 {
 29     int m = val % base;
 30     int q = val / base;
 31     if (q) {
 32         i2a(q, base, ps);
 33     }
 34     *(*ps)++ = (m < 10) ? (m + '0') : (m - 10 + 'A');
 35 
 36     return *ps;
 37 }
我们看一下上面这个函数,它的目的itoa,我们需要将指针变量作为返回地址,它很好的利用了递归函数的特性。
首先,分析函数形参:注意,第三个传入的变量是ps,不是*ps或者**ps。分析内存中的存储情况。

从理论上说,我们只要传入一个指针,就能够实现这个函数。
void itoa(int val,int base,char *str)
{
	int left=val/base;
	int mod=val%base;
	int len=1;	
	*str++=mod;
	while(left!=0)
	{
		left=left/base;
		mod=val%base;
		*str++=mod;
		len++;
	}
	
	//现在,它们逆序存放在str中
	....	
}
数组名称——常量的本质;指针运算中,如果p是指针,P+1的结果取决于指针指向的类型!!!

我们写下这个语句a=b,相像一下,这个对与机器而言意味着什么呢?=是赋值语句,这一句的意思是,b表示b对应变量在内存中的值,a表示一个内存地址。
注意,我们定义了a以后,a有对应的存储单元,但是&a是没有对应存储单元的!