赞
踩
在大家刚开始学习c语言的时候,总是分不清函数指针和指针函数,就算是知道了它们之间的区别,也不了解它们的使用场景,
我写此博客帮大家缕一缕,也帮我自己缕一缕
1、函数指针与指针函数的概念以及区别
指针函数
从名字上可以看出,首先它是一个函数,指针指的是返回值为指针
函数指针
从名字上可以看出,首先他是一个指针,并且是指向函数的指针
2、函数指针与指针函数的区别
①概念上的区别:函数指针值得是指向函数的指针,指针函数指的是返回值为至真的函数。
②功能上的区别:指针函数用来编写返回值为指针的函数,而函数指针可以实现c语言的泛型编程(下面会有例子)
3、函数指针的定义
定义一个求和函数:
- /*求和函数*/
- int sum(int a,int b)
- {
- return a+b;
- }
-
- int (*p)(int a,int b) = sum;/*将指向函数的指针赋给p*/
- int (*p)(int a,int b) = ∑
-
- /*这两种种定义的方法都可以定义一个函数指针*/
-
- int c = p(5.6);
- intc = *p(5,6);/*两种方法都可以通过指针调用函数*/
4、函数指针和指针函数的应用实例
①先说说指针函数的应用(这个是很简单的)
- #include <stdio.h>
-
-
- int* sum(int a, int b)//返回一个指针
- {
- static int c = a + b;
- return &c;
- }
- int main()
- {
- int m,n;
- scanf("%d%d",&m,&n);
-
- int c = *sum(m,n);
- printf("%d",c);
- }
②指针函数的应用(泛型编程)/*重点*/
在c语言里函数是不能够同名的,在以前看来,一个函数只能干对应一件事,比如说写一个由小到大
排序的函数,那么这个函数就只能实现由小到大的排序,要想从大到小排序就得重写一个函数,现在
有了函数指针,我们就可以把指针到一个参数参数传进去,就可以用一个函数实现一个两种排序啦,
代码如下:
- #include <stdio.h>
-
- void swap(int *a,int *b)
- {
- int temp = *a;
- *a = *b;
- *b = temp;
- }
-
- int sort_large_to_small(int a,int b)
- {
- if(a < b)
- {
- return 1;
- }
- return 0;
- }
-
- int sort_small_to_large(int a, int b)
- {
- if(a > b)
- {
- return 1;
- }
- return 0;
- }
-
- void sort(int n, int* arr, int (*p)(int a,int b))
- {
- for(int i = 0;i < n;i++)
- {
- for(int j = 0;j < n-i-1;j++)
- {
- if(p(arr[j],arr[j+1]))
- {
- swap(&arr[j],&arr[j+1]);
- }
- }
- }
- }
-
- int main()
- {
- int arr[] = {12,23,65,45,23,34,100,89,90};
- int n = sizeof(arr)/sizeof(arr[0]);
-
- sort(n,arr,sort_small_to_large);
- printf("由小到大排:");
- for(int i = 0;i < n;i++)
- {
- printf("%d ",arr[i]);
- }
- printf("\n");
-
- sort(n,arr,sort_large_to_small);
- printf("由大到小排:");
- for(i = 0;i < n;i++)
- {
- printf("%d ",arr[i]);
- }
- printf("\n");
-
- return 0;
- }
输出如下:
从代码中可以观察到,我们只是写了一个函数,在冒泡比较的时候控制他们的顺序,
通过函数指针传进去,这样就可以一个函数即可以由小到大排序,也可以由大到小
排序了。这就达到了一定程度上的泛型编程。
以上即是函数指针和指针函数的内容,若读者发现错误,欢迎纠错
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。