news 2026/6/24 19:41:04

《Unreal 对 C++ 做了什么》系列 05. UFUNCTION:让函数在引擎内可见 (RPC, Exec, Blueprint)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
《Unreal 对 C++ 做了什么》系列 05. UFUNCTION:让函数在引擎内可见 (RPC, Exec, Blueprint)

《Unreal 对 C++ 做了什么》系列 (05/54)

05. UFUNCTION:让函数在引擎内可见 (RPC, Exec, Blueprint) ⚡

🚀 导言:超越 C++ 的调用限制

在标准 C++ 中,调用函数是“硬跳转”:编译器在编译期确定内存地址。但在虚幻引擎中,函数需要具备**“动态分发”**的能力。UFUNCTION宏通过“劫持”函数名,在静态的 C++ 之上构建了一套动态调用体系。

📊 核心对比:标准 C++ vs. 虚幻 C++

特性标准 C++ 函数虚幻 C++ (UFUNCTION)
可见性仅限代码链接期全局运行时可见,蓝图/编辑器可识别
调用方式内存地址直接跳转支持字符串搜索调用、网络转发调用
多态性依赖原生虚函数表 (vtable)支持蓝图重写、C++/脚本混合多态
参数传递栈/寄存器传参支持通过反射数据包(Stack Buffer)传参

🛠️ 关键说明符:赋予函数“超能力”

通过在UFUNCTION()中添加不同的说明符,你可以精准定义函数在引擎中的身份。

1. 蓝图交互类
  • BlueprintCallable:最常用的标记,让函数在蓝图中作为一个节点被手动调用。
  • BlueprintPure:定义“纯函数”。这种函数没有执行线(白线),通常用于获取数据而不改变对象状态。
  • BlueprintImplementableEvent:C++ 声明触发,蓝图完全实现。
  • BlueprintNativeEvent:C++ 提供默认实现(_Implementation),蓝图可以重写。
2. 网络 RPC 类
  • Server:客户端调用,服务器执行。
  • Client:服务器调用,特定客户端执行。
  • NetMulticast:服务器调用,所有连接的客户端同步执行。
  • **Reliable/Unreliable**:定义网络包是否必须到达(可靠性)。
  • WithValidation:要求必须实现_Validate逻辑,用于服务器防外挂检查。
3. 编辑器与调试类
  • Exec:将函数变为控制台命令,在游戏中按~键输入函数名即可运行。
  • CallInEditor:在编辑器的属性面板中生成一个按钮,点击即可在非运行状态下触发该函数。
  • Category:定义函数在蓝图搜索列表中的目录分类。
4. 元数据类 (meta)
  • meta = (AllowPrivateAccess = "true"):允许私有函数在蓝图中被访问。
  • meta = (WorldContext = "WorldContextObject"):标记某个参数为世界上下文,蓝图调用时会自动填充,无需手动连线。

🔑 核心黑科技:Thunk (exec) 函数

当你编译一个带有UFUNCTION的类时,UHT 会在.generated.cpp中为你生成一个以exec开头的静态函数。这就是Thunk 函数

1. 为什么需要 Thunk?

蓝图虚拟机(VM)手里只有一个uint8*类型的栈空间(Stack Buffer)。Thunk 的工作就是“翻译”:它从虚拟机栈中取出字节,转换成真实的 C++ 类型,然后再调用你写的函数。

2. Thunk 的内部长什么样?(伪代码)
voidAMyActor::execNativeEvent(FFrame&Stack,RESULT_DECL){P_GET_PROPERTY(FFloatProperty,Value);// 从栈里解析出参数P_FINISH;P_NATIVE_BEGIN;this->NativeEvent_Implementation(Value);// 真正调用你的 C++P_NATIVE_END;}

💻 代码实战:四种不同的实现姿势

1. 声明部分 (MyActor.h)
UCLASS()classAMyActor:publicAActor{GENERATED_BODY()public:UFUNCTION(BlueprintCallable)voidSimpleCall();UFUNCTION(BlueprintNativeEvent)voidNativeEvent(floatValue);UFUNCTION(BlueprintImplementableEvent)voidOnlyBlueprintEvent();UFUNCTION(Server,Reliable,WithValidation)voidServer_UpdateHealth(floatNewHealth);};
2. 实现部分 (MyActor.cpp)
voidAMyActor::SimpleCall(){UE_LOG(LogTemp,Warning,TEXT("Simple Call"));}voidAMyActor::NativeEvent_Implementation(floatValue){UE_LOG(LogTemp,Warning,TEXT("Default C++ Logic"));}// OnlyBlueprintEvent 无需且禁止在 .cpp 实现boolAMyActor::Server_UpdateHealth_Validate(floatNewHealth){returnNewHealth>=0.0f;// 防外挂校验}voidAMyActor::Server_UpdateHealth_Implementation(floatNewHealth){CurrentHealth=NewHealth;}

🛠️ 总结速查表:实现规范与幕后英雄

UFUNCTION 类型实现后缀是否有 Thunk (exec)核心逻辑流
BlueprintCallableVM -> Thunk -> C++ 原生函数
BlueprintNativeEvent_Implementation原名函数 -> (判断) -> 蓝图或 C++ Impl
BlueprintImplementableEvent无实现原名函数 -> 直接丢给 VM 执行蓝图
Server / Client_Implementation原名函数 -> 网络序列化 -> 远端 Thunk -> Impl

结语

UFUNCTION是通过Thunk 函数抹平了强类型 C++ 与动态虚拟机之间的鸿沟。你写下的每一行_Implementation,都在这套名为“反射”的宏大剧本中扮演着保底逻辑的角色。


下一篇我们将探讨:《06. UE 的枚举与接口:UENUM 和 UINTERFACE》

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/24 5:13:04

AnimatedDrawings:5步开启AI动画创作新世界

AnimatedDrawings:5步开启AI动画创作新世界 【免费下载链接】AnimatedDrawings Code to accompany "A Method for Animating Childrens Drawings of the Human Figure" 项目地址: https://gitcode.com/GitHub_Trending/an/AnimatedDrawings 想让孩…

作者头像 李华
网站建设 2026/6/25 8:08:51

AWS微服务监控实战:如何实现全链路可观测性与智能告警

作为AWS高级咨询合作伙伴的解决方案架构师,我曾帮助超过30家企业构建现代化的微服务监控体系。今天我将分享一套完整的可观测性框架,帮助您在微服务架构下实现端到端的监控、诊断和智能告警,将平均故障恢复时间(MTTR)从小时级降低到分钟级。 引言:监控的“盲人摸象”困境…

作者头像 李华
网站建设 2026/6/25 0:01:57

分布式数据库查询性能的深度革命:当DDS遇见现代数据挑战

引言:数据洪流时代的查询困境 2025年双十一零点,阿里巴巴的OceanBase数据库创下了一个记录:每秒处理6100万次查询。这个数字背后,是一个更加深刻的现实:在数据量呈指数级增长的今天,传统的单体数据库架构已…

作者头像 李华
网站建设 2026/6/24 9:00:59

Telegram机器人在欧洲凭证钓鱼中的协同机制与防御路径

摘要近年来,即时通讯平台因其开放的Bot API和高用户渗透率,逐渐被网络犯罪组织武器化。2025年下半年,欧洲多国安全机构联合披露一类新型凭证钓鱼活动,其核心特征是以Telegram机器人作为攻击控制中枢,实现钓鱼模板分发、…

作者头像 李华
网站建设 2026/6/24 20:04:52

为何国家级项目强制要求Agent接口合规?4个真实事故案例警示,

第一章:跨领域 Agent 接口标准的演进与战略意义在人工智能与分布式系统深度融合的背景下,跨领域 Agent 接口标准的演进已成为推动智能体协同、互操作和规模化部署的核心驱动力。随着多智能体系统(MAS)在金融、医疗、智能制造等领域…

作者头像 李华
网站建设 2026/6/24 19:31:38

LOOT智能排序工具:模组管理的最佳解决方案

LOOT智能排序工具:模组管理的最佳解决方案 【免费下载链接】skyrimse The TES V: Skyrim Special Edition masterlist. 项目地址: https://gitcode.com/gh_mirrors/sk/skyrimse 在《上古卷轴V:天际 特别版》的模组世界中,LOOT智能排序…

作者头像 李华