函数指针与返回指针的函数
如下两个例子
1. int* lpfun(int,int);
2. int (*lpfun)(int,int);
第一种是我们熟悉的函数指针,即函数的返回值为int类型的指针
第二种一定要用括号把*号和lpfun括起来,这种类型与第一种不一样,是指向一种函数地址的指针。这个函数的返回类型是int型,实参也为int型。
#include <stdio.h>
using namespace std;
int* lpfun1(int,int); //声明一个返回指针为int类型的函数
int lpfun2(int,int); //普通函数
typedef int (*lpfunPointer)(int,int); //声明一个函数指针类型,用于保存它要指向的函数地址
void main()
{
int *result=lpfun1(10,20);
printf("%d\n",*result);
delete result; //删除堆中的指针
result=0; //使指针无效
lpfunPointer p=lpfun2; //保存lpfun2函数的地址,函数名也是一种指针
printf("%d\n",p(12,60)); //调用带参的函数
}
/***********************************************************************************************
lpfun1过程说明:
如果我们在此函数中这样写: int *p=NULL;
*p=x+y;
return p;
这样的写法是错误的,因为在函数中声明的变量在函数执行完后就不存了,即此是p不存了,是个无效指针,就不能得到这个返回值。
而如果在堆中开辟一小内存来存放,并在完成后由手工来释放,则我们可以用int* p=new int;来创建,这样即使函数没了,但
这个p还是存在于堆中的,由此我们会看到在main()中用了一个int *result=lpfun1(10,20)把堆中的p指针指向result指针,再
手工释放。 这样就不会内存泄露了。
谨记:永远不要从函数中返回局部自动变量的地址。
******************************************/
int* lpfun1(int x,int y)
{
int *p=new int(0);
*p=x+y;
return p;
}
int lpfun2(int x,int y)
{
return x+y;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· .NET Core 中如何实现缓存的预热?
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统