不要伤害指针(4)--指针和函数的关系
2014-12-09 13:28
253 查看
可以把一个指针声明成为一个指向函数的指针.
int fun1(char *,int);
int (*pfun1)(char *,int);
pfun1 = fun1;
int a = (*pfun1)("abcdefg",7); //通过函数指针调用函数。可以把指针作为函数的形参。在函数调用语句中,可以用指针表达式来作为实参。
完全可以想象在内存的代码区有一个对象,通过这个对象.某个函数可以运行这个函数。我们这里的函数名和函数指针都是指向这个对象的。所以下面的几种调用都是合法的。
这个例子中的函数fun 统计一个字符串中各个字符的ASCII 码值之和。前面说了,数组的名字也是一个指针。在函数调用中,当把str作为实参传递给形参s 后,实际是把str 的值传递给了s,s 所指向的地址就和str 所指向的地址一致,但是str 和s 各自占用各自的存储空间。在函数体内对s 进行自加1 运算,并不意味着同时对str 进行了自加1 运算。
int fun1(char *,int);
int (*pfun1)(char *,int);
pfun1 = fun1;
int a = (*pfun1)("abcdefg",7); //通过函数指针调用函数。可以把指针作为函数的形参。在函数调用语句中,可以用指针表达式来作为实参。
完全可以想象在内存的代码区有一个对象,通过这个对象.某个函数可以运行这个函数。我们这里的函数名和函数指针都是指向这个对象的。所以下面的几种调用都是合法的。
#include <stdio.h> #include <stdlib.h> int func(char *s) { int num = 0; while(*s != '\0') { num += *s; s++; } return num; } int main(void) { char str[] = "abc"; int (*pfunc)(char *s); pfunc = func; //各种合法的调用 printf("%d\n", (*pfunc)(str));//通过对象实体调用 printf("%d\n", (*func)(str));//通过对象实体调用 printf("%d\n", func(str));//通过指针调用 printf("%d\n", pfunc(str));//通过指针调用 system("pause"); return 0; }
这个例子中的函数fun 统计一个字符串中各个字符的ASCII 码值之和。前面说了,数组的名字也是一个指针。在函数调用中,当把str作为实参传递给形参s 后,实际是把str 的值传递给了s,s 所指向的地址就和str 所指向的地址一致,但是str 和s 各自占用各自的存储空间。在函数体内对s 进行自加1 运算,并不意味着同时对str 进行了自加1 运算。
相关文章推荐
- 不要伤害指针(3)--指针和结构类型的关系
- 函数指针玩得不熟,就不要自称为C语言高手(函数指针是解耦对象关系的最佳利器,还有signal)
- 条款31: 千万不要返回局部对象的引用,也不要返回函数内部用new初始化的指针的引用 (转自effective c++ second edition)
- 深入理解 C++ 指针(七)---指针和函数的关系
- C语言指针与函数的关系
- 不要伤害指针(6)--指针的安全问题
- 不要伤害指针(5)--void和void指针详解
- 第七章。指针和函数的关系
- C函数关于qsort最后一个函数指针参数指向的函数的返回值和升序排序的关系
- 函数调用时对象指针与对象引用的区别与关系
- 函数名和指针的关系
- 条款 31: 千万不要返回局部对象的引用,也不要返回函数内部用 new 初始化的 指针的引用
- 第七章 指针和函数的关系
- C/C++的函数名和函数指针的关系剖析
- effective C++笔记之条款31、32: 千万不要返回局部对象的引用,也不要返回函数内部用new初始化的指针所指对象的引用、尽可能地推迟变量的定义
- 条款31: 千万不要返回局部对象的引用,也不要返回函数内部用new初始化的指针的引用
- 不要返回局部对象的引用,也不要返回函数内部用new初始化的指针的引用
- 函数 千万不要返回“局部对象”的引用或者指针
- 不要用函数的指针参数去获取函数内部的内存
- 不要伤害指针(2)--指针的类型和指针所指向的类型