指针(一)参数传递
以下是经典程序(载自林锐的从c/c++高质量编程),讲解的部分是我个人理解
void GetMemory(char *p,int num)
{
p=(char*)malloc(sizeof(char)*num); //p是形参指向的地址
}
void main()
{
char *str=NULL;
GetMemory(str,100); //str是实参指向的地址,不能通过调用函数来申请内存
strcpy(str,"hello");
}
结构是编译能通过,却不能运行,为什么呢?
先说一下指针作为函数参数的意义:当将指针作为参数时,实参向形参传递的是地址,在函数执行过程中,既可以对该参数指针变量保存的地址进行处理,也可以对该参数指针变量所指向的数据进行处理,(以上程序段来说就是可以对p或*p进行处理)。
个人觉得:
调用函数GetMemory相当于(char *p=str,int num=100), 调用该函数,重新定义了一个变量p,为该变量申请内存空间,又把str这个变量的值赋值给参数p,指针变量也是变量,在GetMemory函数中(这指针变量本身有地址,而作为变量又保存着一个地址)
如果对P进行操作,那就看成是对变量str的值传递了一份拷贝进来,即按值传递(操作的只是变量p的副本),对于str这个变量来说无关,
这时编程人员的意图如果是想改变变量P的值那就注定失败了。(如果想改变变量的值传递变量的地址进去,不管它是指针变量还是一般的变量)。。。(在一个没有函数调用的代码中,如果经过char *p=str,然后你想通过p来改变str该变量保存的值,你觉得可能么。只能是&p.)。。。( p与str这两个变量保存同一块地址,所以对*p也就是对*str的操作)
void GetMemory(char **p,int num)
{
*p=(char*)malloc(sizeof(char)*num); //此时*p就变成了是形参本身的地址
}
void main()
{
char *str=NULL;
GetMemory(&str,100); //&str是实参的地址,所以实参和形参之间就可以直接调用
strcpy(str,"hello");
free(str);
当对*p进行操作时就看成是按地址传递(对该参数指针所指向的数据进行处理)。此时操作的是str对象保存的地址,该地址上的值。
指针(二)函数指针
注意:int *func( )和int (*func)( )的区别
int *func( ); //这是返回一个整型指针的函数
int (*func)( ); //这是一个函数指针
bool up(int a,int b) {return b<a;} //两个简单的函数,执行着相反的功能
bool down(int a,int b) {return b>a;}
void sort(int array[],const int size,bool (*comp)(int,int))
sort(myintarray,myintarraysize,up);