UE5——网络——RPC

RPC(这个是官方文档的资料)

要将一个函数声明为 RPC,您只需将 Server、Client 或 NetMulticast 关键字添加到 UFUNCTION 声明。

例如,若要将某个函数声明为一个要在服务器上调用、但需要在客户端上执行的 RPC,您可以这样做:

   UFUNCTION( Client )void ClientRPCFunction();

要将某个函数声明为一个要在客户端上调用、但需要在服务器上执行的 RPC,您可以采取类似的方法,但需要使用 Server 关键字:

UFUNCTION( Server )void ServerRPCFunction();

此外,还有一种叫做多播(Multicast)的特殊类型的 RPC 函数。多播 RPC 可以从服务器调用,然后在服务器和当前连接的所有客户端上执行。 要声明一个多播函数,您只需使用 NetMulticast 关键字:

UFUNCTION( NetMulticast )void MulticastRPCFunction();

要求和注意事项

多播 RPC 还可以从客户端调用,但这时就只能在本地执行。

1.您必须满足一些要求才能充分发挥 RPC 的作用:2.它们必须从 Actor 上调用。3.Actor 必须被复制。4.如果 RPC 是从服务器调用并在客户端上执行,则只有实际拥有这个 Actor 的客户端才会执行函数。5.如果 RPC 是从客户端调用并在服务器上执行,客户端就必须拥有调用 RPC 的 Actor。6.多播 RPC 则是个例外:如果它们是从服务器调用,服务器将在本地和所有已连接的客户端上执行它们。如果它们是从客户端调用,则只在本地而非服务器上执行。现在,我们有了一个简单的多播事件限制机制:在特定 Actor 的网络更新期内,多播函数将不会复制两次以上。按长期计划,我们会对此进行改  善,同时更好的支持跨通道流量管理与限制。

例子

Client (服务器的调用客户端执行)

	UFUNCTION(Server, Reliable)void FunctionServer();UFUNCTION(Client, Reliable)void FunctionClient();
void ARPCProjectCharacter::FunctionServer_Implementation()
{GEngine->AddOnScreenDebugMessage(-1, 5.f, FColor::Red, TEXT("FunctionServer"));UE_LOG(LogTemp,Warning,TEXT("FunctionServer"));FunctionClient();
}
void ARPCProjectCharacter::FunctionClient_Implementation()
{GEngine->AddOnScreenDebugMessage(-1, 50.f, FColor::Red, TEXT("FunctionClient"));UE_LOG(LogTemp,Warning,TEXT("FunctionClient"));
}
void ARPCProjectCharacter::StartFire()
{GEngine->AddOnScreenDebugMessage(-1, 50.f, FColor::Red, TEXT("Click"));UE_LOG(LogTemp,Warning,TEXT("Click"));FunctionServer();
}

在这里插入图片描述

Server (客户端调用服务端执行)

	UFUNCTION(Server, Reliable)void FunctionServer();
void ARPCProjectCharacter::FunctionServer_Implementation()
{GEngine->AddOnScreenDebugMessage(-1, 5.f, FColor::Red, TEXT("FunctionServer"));UE_LOG(LogTemp,Warning,TEXT("FunctionServer"));
}
void ARPCProjectCharacter::StartFire()
{GEngine->AddOnScreenDebugMessage(-1, 50.f, FColor::Red, TEXT("Click"));UE_LOG(LogTemp,Warning,TEXT("Click"));FunctionServer();
}

在这里插入图片描述

NetMulticast (客户端调用服务端执行)

	UFUNCTION(Server, Reliable)void FunctionServer();UFUNCTION(Client, Reliable)void FunctionClient();UFUNCTION(NetMulticast, Reliable)void FunctionNetMulticast();
void ARPCProjectCharacter::FunctionServer_Implementation()
{GEngine->AddOnScreenDebugMessage(-1, 5.f, FColor::Red, TEXT("FunctionServer"));UE_LOG(LogTemp,Warning,TEXT("FunctionServer"));FunctionClient();FunctionNetMulticast();
}
void ARPCProjectCharacter::FunctionNetMulticast_Implementation()
{GEngine->AddOnScreenDebugMessage(-1, 50.f, FColor::Red, TEXT("FunctionNetMulticast"));UE_LOG(LogTemp,Warning,TEXT("FunctionNetMulticast"));
}
void ARPCProjectCharacter::FunctionClient_Implementation()
{GEngine->AddOnScreenDebugMessage(-1, 50.f, FColor::Red, TEXT("FunctionClient"));UE_LOG(LogTemp,Warning,TEXT("FunctionClient"));
}
void ARPCProjectCharacter::StartFire()
{GEngine->AddOnScreenDebugMessage(-1, 50.f, FColor::Red, TEXT("Click"));UE_LOG(LogTemp,Warning,TEXT("Click"));FunctionServer();
}

在这里插入图片描述

官方图表

在这里插入图片描述

验证

UFUNCTION( Server, WithValidation )void FunctiHpServer( int32 AddHealth );
void ARPCProjectCharacter::FunctiHpServer_Implementation(int32 AddHealth)
{}bool ARPCProjectCharacter::FunctiHpServer_Validate(int32 AddHealth)
{if (AddHealth>0){return true;}return false;
}

可靠性

必须将RPC指定为 可靠 或 不可靠。在蓝图中,函数和事件默认为不可靠。要将函数指定为可靠,将细节面板(Details Panel)中的 可靠(Reliable) 设置设为 true。在C++中,必须将 Reliable 或 Unreliable 说明符作为 Server、Client 或 NetMulticast 函数,添加到RPC的 UFUNCTION 宏及其状态。

不可靠RPC无法保证必会到达预定目的地,但其发送速度和频率高于可靠的RPC。其最适用于对gameplay而言不重要或经常调用的函数。例如,由于Actor移动每帧都可能变换,因此使用不可靠RPC复制该Actor移动。

可靠的RPC保证到达预定目的地,并在成功接收之前一直保留在队列中。其最适合用于对gameplay很关键或者不经常调用的函数。相关例子包括碰撞事件、武器发射的开始或结束,或生成Actor。

滥用可靠函数可能导致其队列溢出,此操作将强制断开连接。若逐帧调用复制函数,应将其设为不可靠。若拥有与玩家输入绑定的可靠函数,应限制玩家调用该函数的频率。

网络提示

1.尽可能少用RPC或复制蓝图函数。在合适情况下改用RepNotify。
2.组播函数会导致会话中各连接客户端的额外网络流量,需尤其少用。
3.若能保证非复制函数仅在服务器上执行,则服务器RPC中无需包含纯服务器逻辑。
4.将可靠RPC绑定到玩家输入时需谨慎。玩家可能会快速反复点击按钮,导致可靠RPC队列溢出。应采取措施限制玩家激活此项的频率。
5.若游戏频繁调用RPC或复制函数,如tick时,则应将其设为不可靠。
6.部分函数可重复使用。调用其响应游戏逻辑,然后调用其响应RepNotify,确保客户端和服务器拥有并列执行即可。
7.检查Actor的网络角色可查看其是否为 ROLE_Authority。此方法适用于过滤函数中的执行,该函数同时在服务器和客户端上激活。
8.使用C++中的 IsLocallyControlled 函数或蓝图中的Is Locally Controlled函数,可检查Pawn是否受本地控制。基于执行是否与拥有客户端相关来过滤函数时,此方法十分拥有。
9.构造期间Pawn可能未被指定控制器,因此避免在构造函数脚本中使用IsLocallyControlled

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/156854.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【数据库】形式化关系查询语言(一):关系代数Relational Algebra:基本运算、附加关系代数、扩展的关系代数

目录 一、关系代数Relational Algebra 1. 基本运算 a. 选择运算(Select Operation) b. 投影运算(Project Operation) 组合 c. 并运算(Union Operation) d. 集合差运算(Set Difference Op…

【小白专用】PHP array_push() 函数

PHP array_push() 函数 首先创建一个数组,然后使用array_push()函数依次添加了2个元素,并使用print_r()打印出了结果。可以看到,新添加的元素都已经被成功插入到了数组的末尾。 向数组尾部插入 "blue" 和 "yellow"&…

【spring boot】

作用 极大地简化了spring的搭建和开发 开发方法 idea开发springboot 必须联网 结构 parent:装多次使用的依赖,还能管理版本 starter:SpringBoot中常见项目名称,定义了当前项目使用的所有依赖坐标,以达到减少依赖…

java基础--多线程学习

写在前面: 多线程在面试中问的很多,之前没有过系统的学习,现在来进行一个系统的总结学习 文章目录 基础java多线程实现无参无返回值线程快速创建start和run方法的探讨run方法线程状态 有返回值线程线程池执行小结关于抛出异常的扩展 线程方…

python使用requests+excel进行接口自动化测试

在当今的互联网时代中,接口自动化测试越来越成为软件测试的重要组成部分。Python是一种简单易学,高效且可扩展的语言,自然而然地成为了开发人员的首选开发语言。而requests和xlwt这两个常用的Python标准库,能够帮助我们轻松地开发…

本地仓库转为git仓库推送到gitee

通常有两种获取 Git 项目仓库的方式: 方式一:将尚未进行版本控制的本地目录转换为 Git 仓库; 方式二:从其它服务器 克隆 一个已存在的 Git 仓库。 两种方式都会在你的本地机器上得到一个工作就绪的 Git 仓库。 方式一&#xff1a…

Linux之centos7安装配置及Linux常用命令

🎉🎉欢迎来到我的CSDN主页!🎉🎉 🏅我是君易--鑨,一个在CSDN分享笔记的博主。📚📚 🌟推荐给大家我的博客专栏《LInux实战开发》。🎯🎯 …

java入坑之运行管理

一、概述 1.1Java开发和运行过程 编写阶段:采用各种编辑工具,编写.java文件编译阶段:采用javac.exe对java文件编译,产生.class文件运行阶段:采用java.exe加载.class文件运行 详细过程 1.2相关概念 javaOS管理 JavaOS是…

2023-2024-1 高级语言程序设计-函数

6-1 求m到n之和 本题要求实现一个计算m~n&#xff08;m<n&#xff09;之间所有整数的和的简单函数。 函数接口定义&#xff1a; int sum( int m, int n ); 其中m和n是用户传入的参数&#xff0c;保证有m<n。函数返回的是m~n之间所有整数的和。 裁判测试程序样例&…

excel技巧

excel技巧 &#x1f353;选中&#x1f353;填充&#x1f353;日期&#x1f352;&#x1f352; 日期快捷方式&#x1f352;&#x1f352; 日期计算&#x1f352;&#x1f352;时间相减 &#x1f353;求和&#x1f353;去除小数点&#x1f353;美化表格&#x1f352;&#x1f352…

SpringCloud(三) Ribbon负载均衡

SpringCloud(二) Eureka注册中心的使用-CSDN博客 在SpringCloud(二)中学习了如何通过Eureka实现服务的注册和发送,从而通过RestTemplate实现不同微服务之间的调用,加上LoadBalance注解之后实现负载均衡,那负载均衡的原理是什么呢? 目录 一, 负载均衡 1.1 负载均衡原理 1.2 源…

QMS质量检验管理|攻克制造企业质量检验难题,助力企业提质增效

在日益激烈的市场竞争中&#xff0c;对产品质量严格把关&#xff0c;是制造企业提高核心竞争力与品牌价值的关键因素。那如何高效、高质地完成产品质检工作&#xff1f;这就需要企业在工业质检中引进数字化技术加以辅助&#xff0c;进而推动智能制造高质量发展。 蓝库云QMS质量…