解密《黑神话:悟空》脚本

⭐发布日期:2024年09月20日 | 来源:科普中国

⭐作者:仝向军 责任编辑:Admin

⭐阅读量:769 评论:8人

【香港精准资料期期准】

【精准四肖期期准选一】

【新澳门一码中精准一码免费中特】 【2024天天开好彩大全】 【六和彩十二生肖资料2024今晚开什么】 【澳门六开奖号码今晚开奖结果查询】 【澳门必中一肖一码准一肖】 【2024年新澳门彩开奖结果】 【澳门最准的资料免费公开】 【管家婆开奖结果】
【2024香港开彩开奖结果】 【2024澳门特马今晚开奖49图】 【2024澳门码今晚开奖结果记录】 【4949澳门开奖现场+开奖直播】 【新澳2024年精准资料期期】 【2024奥门今晚开奖结果+开奖记录】 【新澳六开彩开奖号码记录乾坤未定】 【4949澳门彩开奖结果发现】

《黑神话:悟空》这游戏昨天上线了,我第一时间就下载玩了。玩的时候我就挺好奇他们是怎么写的程序,毕竟这么大的游戏项目肯定不会只用C++一种语言来写。所以我解压了游戏文件,看看里面有没有什么线索,结果还真发现了一些有趣的东西。

在游戏正式上线前,官方就发布了一个免费的测试工具,这个工具里其实包含了完整的游戏代码,只是把大部分游戏资源给删掉了。项目组应该是没时间再单独做一个新的测试工程,比起删代码,删资源简单多了,这是程序员都能理解的事情。


引擎版本

一开始他们用的是UE4,后来UE5出来后他们就转用了UE5。现在游戏用的引擎版本是UE5.0.0。虽然Epic后来又发布了UE5.0.3这些更新版本,但项目组一般不会随便升级引擎版本。

他们可能会从新版本里拿一些需要的代码过来用,毕竟如果换引擎的话,之前做的大量定制化改动很难迁移过去。


代码段大小

游戏的exe文件大小达到了859MB,这个大小有点不寻常。相比之下,像《三角洲行动》这样的UE游戏客户端大小是140MB,《极品飞车:集结》客户端大小是105MB。我觉得可能是游戏中包含了太多不必要的插件代码或者是没有去掉一些不需要的符号信息。


技术总监

游戏科学的团队创始人来自腾讯的《斗战神》项目,他们的技术总监招文勇是在2010年加入腾讯量子工作室的,后来这个工作室并入了光子工作室。

文勇是从中山大学软件工程系毕业的,2014年他和冯骥、杨奇等《斗战神》的核心成员一起创立了游戏科学。在这之前,他还担任过《战争艺术:赤潮》的主程。如果有人做过Unity开发并且经常关注Unity Wechat Academy(UWA)的话,应该看过他在UWA平台上的分享文章,其中有一篇写得特别好


曾经分享过一种配置存储方法,就是把配置放在Lua表里,然后用C#的unsafe code来访问这些配置,这样配置数据只需要占用一份内存空间而且还能保持高效。

那时候他们用的是xLua,所以我猜测他们选择的脚本方案可能还是基于Lua的,比如像sluaunreal这种已经在吃鸡手游上验证过的,或者UnLua,因为它维护得比较好。

还有一种可能是他们用了最近车神新出的PuerTS,不过考虑到《黑神话:悟空》立项的时间比较早,应该不会用这两年才兴起的PuerTS,因为切换成本太高。

另外,他们也可能用了C#,但现在市面上的一些C#方案要么没人维护,而且基本上只能在Windows上用,跨平台支持不太好。


脚本方案


我在检查代码符号的时候,发现了好多跟V8有关的内容,所以自然而然地以为他们用了PuerTS,感觉项目组还挺跟得上潮流的。

但是奇怪的是,我没有找到任何跟PuerTS相关的符号。后来我试着搜索"js"这个词,结果发现代码里包含了Unreal.js这个插件。

Unreal.js 这个插件是几年前的东西了,一直都没人维护,直到去年才增加了对 UE5 的支持。看起来《黑神话:悟空》项目组对这个插件做了一些修改。

就这样,我原本以为他们用的就是 Unreal.js,但当我开始解包 pak 文件时,情况有了变化。


Pak解包

解包UE的Pak文件通常需要知道对应的引擎版本和AES密钥,因为不同版本的PakInfo结构会有所不同。

这里就不详细说了,直接说结论吧。我在解包的过程中没有找到像 js、ts 或 wasm 这样的代码文件,所以他们可能继承了Unreal.js插件但并没有真正使用它,或者他们用了其他的方式来存储脚本代码。

但在翻阅Pak文件时,我发现了很多两种类型的二进制文件:.data 和 .Data。小写开头的 .data 文件看起来像是配置文件,而大写开头的 .Data 文件更像是某种代码的二进制形式。

比如 .data 文件中包含的是物品的配置信息,里面似乎记录了物品的蓝图路径和其他配置内容,整体结构类似于protobuf。

.Data 文件看起来就像是某种代码的二进制形式,但按照我的经验,JavaScript(js)或 TypeScript(ts)编译后的代码通常不是这样的形式。这些 .Data 文件倒更像是自定义的状态机代码的样子。

这就有点奇怪了,既没有找到 JavaScript 代码,也没有发现类似 Lua 编译后的代码。但是既然有这种看起来像是二进制代码的文件,那么他们是不是用了 C# 相关的方案呢?

比如 USharp、UnrealCLR 或者 UnrealSharp。我在代码符号中搜索了这些相关的字符串,果然找到了 USharp 的痕迹,并且在 Pak 文件中也发现了 USharp 的 uplugin 文件。所以现在可以确定他们用的就是 USharp。

简单来说,在上面的图中我们可以看到被选中的节点里大量使用了 SharpClass,这是 USharp 中的一个自定义类 UBlueprintGeneratedClass

它的作用是在运行时将 C# 中定义的 UClass 动态地转换成虚幻引擎(UE)能够识别的类型。这样就可以在虚幻引擎中使用 C# 编写的类了。


看起来事情并不那么简单。虽然 USharp 本身并不支持虚幻引擎 5(UE5),也不支持主机和移动设备平台,但在《黑神话:悟空》的项目文件中却包含了对这些平台的支持。

这很可能意味着《黑神话:悟空》的开发者们对 USharp 进行了大量的修改和兼容性改进,以便让它能在 UE5 和不同平台上运行。

尽管如此,我在游戏的打包文件(Pak 文件)中没有找到 JavaScript (js)、Lua (lua) 或者 USharp 的 DLL 文件。这就有点奇怪了,因为在游戏的代码中确实有使用到 Unreal.js 和 USharp 插件的迹象。让我们接着往下探究这个问题。


il2cpp

提到 il2cpp,对于 Unity 开发者来说应该很熟悉。这是 Unity 为了改善 mono 虚拟机的兼容性和性能问题而推出的一种解决方案。简单来说,il2cpp 可以把 C# 代码编译成原生机器码,这样就能提高游戏的运行效率。

然而 il2cpp 是 Unity 专有的技术,用来提高 C# 代码的性能和兼容性,但它通常是和 Unity 引擎绑定在一起的。

在查看《黑神话:悟空》中与 USharp 相关的代码符号时,我发现了一个令人惊讶的情况。《黑神话:悟空》所使用的 USharp 并不是原版的,而是经过了修改,添加了 USharp 运行模式的切换功能。

这意味着他们可以在不同的运行模式之间选择,包括常用的 mono 和 clr 模式,还有 il2cpp 模式!

换句话说,《黑神话:悟空》的团队不仅使用了 USharp,而且还对它进行了大量的定制,使得它能够支持多种不同的运行模式,包括 Unity 的 il2cpp 技术。这表明他们为了让游戏运行更加高效,做了很多额外的工作。

这些不同的运行模式并不是原版 USharp 包含的功能,这意味着项目组为了提高兼容性和性能做了大量的定制和改进。

他们实际上是基于 USharp 重新开发了一个支持多种模式的 C# 脚本方案,包括 mono、clr 和 il2cpp。

既然在 Pak 文件中没有找到 DLL 或脚本文件,那么在正式发布的版本中他们很可能是使用了 il2cpp。这样一来,C# 中定义的所有类型和符号都被编译成了 C++ 代码,并最终整合进了 exe 文件中。这就是为什么 exe 文件会变得如此之大的原因。

如果把 C# 代码打包成 DLL 文件,整个游戏的大小可能只会增加几十 MB,而 exe 文件的大小大概能减少到 100 MB 左右。不过这样做可能会稍微牺牲一些性能。


总结

总结一下,《黑神话:悟空》的脚本方案是基于 USharp 进行了大量定制化的改进,他们自己实现了支持 mono、clr 和 il2cpp 的运行模式,并且这套方案还支持多个平台,包括 PC、Mac、Linux、Android、iOS、PS5 和 Xbox。

此外,虽然游戏的代码中集成了 Unreal.js,但看起来并没有真正使用到它。他们还使用了一种自研的状态机或行为树系统,并且配置表是以 protobuf 结构的二进制数据形式存储的。

需要注意的是,这里只是简单分析了《黑神话:悟空》的脚本方案,并没有涉及任何解包方法或资源破解的信息,请不要用于非法用途。





【2024澳门天天开好彩大全免费】 【新澳天天开奖资料大全最新】
【2024年天天开好彩资料】 【新澳天天开奖资料大全最新54期】
【2024澳门天天开好彩大全53期】 【澳门天天开彩期期精准】
【2024全年资料免费大全】 【新澳天天开奖资料大全】
【澳门内部最精准免费资料】 【2024澳门天天开好彩大全】
【2024年新奥门天天开彩免费资料】 【新澳2024今晚开奖资料】 【2024老澳门开奖记录历史】
上一条新闻 下一条新闻

推荐文章

发表评论

丽芙·乌曼

1秒前:这就有点奇怪了,既没有找到 JavaScript 代码,也没有发现类似 Lua 编译后的代码。

IP:47.41.3.*

矫珂

2秒前:我在代码符号中搜索了这些相关的字符串,果然找到了 USharp 的痕迹,并且在 Pak 文件中也发现了 USharp 的 uplugin 文件。

IP:20.25.7.*

格蕾丝·辛

8秒前:此外,虽然游戏的代码中集成了 Unreal.

IP:99.98.9.*

科普中国APP介绍

APP图标

2024新奥历史开奖直播APP名:科普中国

版本:V2.74.552

更新时间:2024-09-19 20:19

新奥彩今天晚上开奖结果查询表格这是一个功能强大的澳门开奖网APP,可以帮助你完成各种任务。包括最新24小时热点资讯,今日最新:需要注意的是,这里只是简单分析了《黑神话:悟空》的脚本方案,并没有涉及任何解包方法或资源破解的信息,请不要用于非法用途。

2024澳门今晚开特马开什么APP介绍

APP图标

新奥六开彩开奖结果查询合肥APP名:科普中国

版本:V3.53.204

更新时间:2024-09-19 21:20

新澳门资料大全免费新鼬077这是一个功能强大的2024年澳门开奖结果记录APP,可以帮助你完成各种任务。包括最新24小时热点资讯,今日最新:Data 文件更像是某种代码的二进制形式。

香港伦坛开码开奖结果APP介绍

APP图标

澳门开奘记APP名:科普中国

版本:V4.33.376

更新时间:2024-09-19 18:19

刘伯温四肖八码期期准精选风险这是一个功能强大的2024年今晚澳门开奖结果APP,可以帮助你完成各种任务。包括最新24小时热点资讯,今日最新:这里就不详细说了,直接说结论吧。

2024新奥开奖记录APP介绍

APP图标

香港今期开奖结果查询结果71期APP名:科普中国

版本:V8.49.846

更新时间:2024-09-19 23:24

香港澳门资料大全香港t开什么号这是一个功能强大的2024年澳门必中三肖是几期APP,可以帮助你完成各种任务。包括最新24小时热点资讯,今日最新:Data。

2024澳门天天开彩结果APP介绍

APP图标

2024新澳免费资料大乐季APP名:科普中国

版本:V4.86.413

更新时间:2024-09-19 24:21

新奥门资料免费资料大全这是一个功能强大的494949开奖历史记录最新开奖记录APP,可以帮助你完成各种任务。包括最新24小时热点资讯,今日最新:后来我试着搜索"js"这个词,结果发现代码里包含了Unreal.

澳门今天晚上的图片APP介绍

APP图标

2024澳门天天开好彩大全46APP名:科普中国

版本:V3.38.314

更新时间:2024-09-19 22:13

港r六合e.彩开码日这是一个功能强大的2024澳门免费精准资料大全APP,可以帮助你完成各种任务。包括最新24小时热点资讯,今日最新:看起来《黑神话:悟空》项目组对这个插件做了一些修改。

澳门六开彩资料查询最新2024年网站APP介绍

APP图标

新澳彩66期开奖结果查询APP名:科普中国

版本:V6.51.209

更新时间:2024-09-19 23:21

澳门一肖一码100准免费资料这是一个功能强大的新澳门开码结果APP,可以帮助你完成各种任务。包括最新24小时热点资讯,今日最新:文勇是从中山大学软件工程系毕业的,2014年他和冯骥、杨奇等《斗战神》的核心成员一起创立了游戏科学。

20224年澳门出什么生肖APP介绍

APP图标

澳门六开奖结果2024开奖直播APP名:科普中国

版本:V5.17.630

更新时间:2024-09-19 21:15

新奥精准资料免费提供510期这是一个功能强大的2024年澳门今晚开奖号码生肖APP,可以帮助你完成各种任务。包括最新24小时热点资讯,今日最新:data 和 .