子线程渲染技术和AC自动机

简介: 子线程渲染技术和AC自动机

子线程渲染技术

原因:在玩家较多,且时装坐骑等差异化较大时,客户端帧率低,卡顿明显

思路:将渲染放在子线程进行,使逻辑处理和渲染可以同时进行,提高并行处理能力,提高客户端运行效率,提升帧率,缓解卡顿

方案:1、创建一个新的线程专门用来处理渲染逻辑          


          2、将主线程每一种渲染函数和一些设置渲染状态的方法都定义成一种渲染类型        


          3、每一个渲染类型对应一个渲染结构,包含渲染的数据和render方法          


           4、用std::array<std::vector<renderinfo*>, 2>这种结构来存储渲染数据,这样分开逻辑线程和渲染线程的访问冲突,逻辑线程向一个vector中写入数据,渲染线程从另一个已经写好的vector中读取数据执行渲染          


            5、逻辑线程和渲染线程执行速度会有差异,需要通过std::mutex互斥量来使两个线程协同工作(设置某个线程等待以及唤醒)


587a3cee84ed48fca0b2f4512e48b26b.png

问题3:游戏最小化、修改分辨率、锁屏等操作,恢复后显示异常 原因:这些操作会导致DX设备丢失,需要通过TestCooperativeLevel获得当前设备情况,正确调用ResetDevice()函数


注意:1、保证DX渲染接口的调用都在渲染线程执行          


         2、对渲染有影响的成员变量要区分逻辑线程和渲染线程      


         3、渲染顺序和以前主线程保持一致


结果:客户端机器人身上时装是随机的,不会移动、不释放技能        


          添加1024个机器人      以前帧数  21左右    现在帧数   45左右          


         添加2048个机器人      以前帧数  10左右    现在帧数   22左右


2。屏蔽字匹配优化:AC自动机(多模字符串匹配算法)


原因:屏蔽字是采用字符串匹配方式做的,屏蔽字列表文件就有好几个,并且有的文件屏蔽字字符串有接近2W行,效率低


算法:1、构造字典树            


          2、构造适配指针        


          3、匹配过程

image.png

结果:1、AC自动机的匹配效率要高很多      

          2、创建AC自动机所需要的内存较大 是一种空间换时间的算法

         

关于AC自动机的一些链接:

AC自动机(详解)_tweatherm的博客-CSDN博客_ac自动机

相关文章
|
8月前
|
前端开发 JavaScript API
链式编程艺术:探索 Promise 链的美妙之处
链式编程艺术:探索 Promise 链的美妙之处
|
3月前
|
编译器 程序员 C语言
精简函数栈帧:优化创建和销毁过程的完全解析(建议收藏,提升内功)
精简函数栈帧:优化创建和销毁过程的完全解析(建议收藏,提升内功)
|
2月前
|
XML 安全 Java
Java反射机制:解锁代码的无限可能
Java 反射(Reflection)是Java 的特征之一,它允许程序在运行时动态地访问和操作类的信息,包括类的属性、方法和构造函数。 反射机制能够使程序具备更大的灵活性和扩展性
50 5
Java反射机制:解锁代码的无限可能
|
8月前
|
小程序 算法 UED
【专栏】小程序图片合成就绪渲染的转变,从异步并发渲染到同步阻塞渲染
【4月更文挑战第29天】本文探讨了小程序图片合成就绪渲染的转变,从异步并发渲染(提高效率,并发处理但可能导致资源竞争和顺序难控)到同步阻塞渲染(顺序可控,资源管理更精细,可能引起界面卡顿)。同步阻塞通过任务队列和阻塞机制确保顺序,解决并发问题。注意避免长时间阻塞,及时释放资源,优化任务效率,并结合异步处理。选择合适方案取决于实际需求,以平衡效率与一致性。
103 1
|
8月前
|
存储
【函数栈帧解析:代码的迷人堆积和无限嵌套】(上)
【函数栈帧解析:代码的迷人堆积和无限嵌套】
128 0
|
8月前
|
存储 编译器 C++
【函数栈帧解析:代码的迷人堆积和无限嵌套】(下)
【函数栈帧解析:代码的迷人堆积和无限嵌套】
|
8月前
在程序运行过程中,线程的状态是什么?进来看看就通透了
在程序运行过程中,线程的状态是什么?进来看看就通透了
60 0
|
Java
多线程交替输出A1B2C3D4...你怎么实现?
多线程交替输出A1B2C3D4...你怎么实现?
94 0
三个线程按顺序打印ABC?十二种做法,深入多线程同步通信机制
大家好,我是老三,这篇文章分享一道非常不错的题目:三个线程按序打印ABC。 很多读者朋友应该都觉得这道题目不难,这次给大家带来十二种做法,一定有你没有见过的新姿势。