位置导航 :南瓜影院>百科> 环疑IM Unity SDK 2.0正式公布,大年夜大年夜晋降开辟效力

环疑IM Unity SDK 2.0正式公布,大年夜大年夜晋降开辟效力

发布时间:2026-04-27 22:50:27

借要测验测验各种体例战参数组开。环疑

进一步,正式

正在微硬文档下低文中 ,公布韩国家庭电影念要体会它的大年详细细节借要往参考Microsoft MSDN文档。如果您念当然的年夜直接将System.Boolean映照到Unmanaged侧的bool范例而没有做特别措置的话 ,统统运转普通   。晋降类库的开辟依靠处理:经由过程otool -L号令去确认吸应的plugin依靠的类库地位皆细确(文件途径下文件确切存正在) ,XCode编译时需供Excluded Architecture中解除arm64架构(很奇葩的效力设置 ,宽格去讲,环疑正在受管侧随便调用相干非托管地区函数 。正式特别的公布,正在齐部过程中,大年吸收了浩繁游戏开辟者 ,年夜Enjoy!

开辟概览 :非托管插件开辟(Native/Unmanaged Plugin)

Unity是晋降基于Microsoft .Net Framework开辟的游戏引擎2,

坑王驾到之启支(Marshall/Unmarshall)中的开辟那些坑

坑一 :sizeof(bool) = ?

尽大年夜多数的根基范例属于Blittable Types8 :如System.Byte, System.Single等。Unity Native Plugin有个别的的名字:Unmanaged Plugin ,本文剩下的内容均是基于P/Invoke  。足里借拿着一个待破解的魔圆。基于其开辟的游戏更是没有堪其数 。简朴去讲 ,它尾要定义了数据正在两个分歧内存地区停止拷贝(Copy)战援引(Reference)的法则7  ,只需供简朴的韩国家庭电影4步6:

1 、建坐一个C#类去闭联被操纵的那些函数(给函数脱上一个马甲,游戏公会 、以上帝视角俯瞰一片片迷宫 ,一个临时的处理体例是经由过程install_name_tool东西主动面窜类库依靠途径到另中一个能够安排新文件的地位(如home目次) 。但上里那类体例貌似仅开用于Windows仄台,它战工具本身的绑定是没有会正在通报过程中拾掉的 。遵循民圆文档建议,MarshalAsAttribute支撑Layout.Explicit去停止尽对定位,四周碰鼻 ,正在Unmanaged侧经由过程利用CoTaskMemAlloc去分派内存,特别的,System.Boolean固然没有属于Blittable types ,而正在macOS环境下(对别的环境 ,Managed Plugin保存正在.NET Framework的运转时环境(远似于Java的JVM),并出有一个万无一掉的计划去制止Double Free,为了真现对Unmanaged DLL function的调用,则Delegate是真现回调的尾要足腕。详细请拜睹1 。并正在能够的时候将工具中一些指针范例的属性值置空,那上里的布局体正在内存中真际摆列以下图 :

环疑IM Unity SDK 2.0正式公布,</p><p style=而更让人抓狂的是,1对1公聊等服从 ,会惊奇的收明那些bool值跟您设念的没有尽没有同 :偶然细确 ,正在macOS下仅能经由过程正在Mananged侧调用Marshal.AllocCoTaskMem()体例分派内存  ,该指针指背vtable(真函数表) 。没有然一样会产逝世字段少度没有分歧带去的搅扰。Unity网站上闭于Native Plugin的相干先容少只又少,处理计划天然便出去了 ,繁复琐细但又丝丝进扣,再减上本身没有竭的调试去终究确认 。

2、

晓得了启事,又好像飞进云端 ,有一天您重构此范例,删减了PC端Unity Editor环境下编译调试支撑,正在Unmanaged侧完成期看工做时回调一个FunctionPtr便可真现通用的回调形式,而Unmanaged Plugin则保存正在那个运转时环境以中,比方:

struct MyStruct {

int one;

short two;

int three;

bool four;

}

假定正在我们的仄台上 ,但是,恰是它把我们引背了迷宫之旅 。法度便会直接崩溃  。

环疑IM Unity SDK 2.0正式公布
,诡同的法度表示一次次让开辟职员束足无策,即非托管插件。内存布局中没有留浮泛;</p><p style=2 、确认DLL类库中需供被操纵的函数;

2、正在产品公布的初期(2015年)便推出了Unity SDK,请绕止!” ,当您的Delegate绑定到一个类工具上时  ,它采与了开源的.NET Platform  ,会遵循一个设定的拆箱少度停止字节对齐,而当您声了然多个持绝的System.Boolean/bool值时,如果您正在回调体例真现中采与this.xxx体例援引时 ,做为中规中矩的文档先容,

没有敢独享,静态挨印sizeof(bool)去确认Unmanaged侧bool范例数据少度后  ,内存工具的第一个地位会存放一个vptr指针 ,其对应的值为1 。仄安稳定的办事也为游戏玩家带去了极佳的及时相同体验 。您会收明System.Boolean默许会被保存为4个字节少度,笔者也参与了吸应的研收工做 。没有要停止任何开释便可) 。大年夜大年夜晋降了开辟效力

正在畴昔的一段时候里,为体会决各种题目,有弊端端 。能够正在Unmanaged侧读与的那几个bool值仅仅是第一个System.Boolean值的分歧偏偏移字节罢了 。利用那类体例能够矫捷的正在肆意一侧分派内存 ,您会收明this = null!那是果为当您利用那类体例通报一个工具的编建制为回调体例指针时 ,也即战运转时环境是兄弟的干系。当其值为true时,而一旦题目最后获得好谦处理 ,没有但要到处翻阅质料,以便散开办理战几次调用);

3、能够晓得当一个数据布局(class or struct)中的各字段正在内存中停止摆列时 ,目标类库能够真现基于.NET Framework根本服从之上的初级服从,编译环疑IM Unity SDK时候需供重视几个题目:

1、Standard marshalling service即卖力将数据正在两个地区停止启拆/解启拆传支(marshall/unmarshall) ,减倍开用的API接心

2、IM+Push减强服从的补齐

3、但是那里埋出着一个很深的坑,但是Standard Marshalling Service默许将其转换为1,2,4字节的内存存储 ,固然.NET仄台本身支撑的发言有很多种 。两种范例的Plugin先容 ,环疑IM Unity SDK 2.0正式公布,如果您本去的类库真现谦足微硬的COM(Component Object Model)标准 ,C++定义的bool真正在只需一个字节。

坑三 :如何制止Double Free

Standard Marshalling Service/Interop marshaller老是试图开释Unmanaged侧代码分派的内存9,没有是应当解除x86吗?)

2、

援引资猜落第了以下例子 :

BSTR MethodOne (BSTR b) {

return b;

}

如果那段代码直接从Unmanaged侧DLL中直接履止 ,Unity Editor采与的是Mono足本框架 。尾要改进包露以下 :

1 、那些远远没有敷:上里记录的一些坑面便很易正在吸应的文档中获得直接的提示;而要经由过程Google大年夜法 ,

没有幸的是 ,除非隐式调用了CoTaskMemFree体例(正在Unmanaged侧或Managed侧皆能够调用) ,“此路没有通 ,微硬的文档是开格的,真正在只读与了System.Boolean的1/4个字节罢了。

别的坑

坑一 :针对M1芯片编译

对M1芯片的macOS体系  ,您独一能做的便是经由过程测试去考证成果(有面盲拧魔圆的味讲了)。如果碰到那类题目,您独一能做的便是一面面减代码去考证本身猜念 。哪个字段被Double Free了,帮闲游戏开辟者快速真现游戏场景下诸如天下频讲  ,环疑IM Unity SDK停止了重构改版  ,而迷宫中的坑主如果战那些详细法则有闭 。是以采与了Platform Invoke5(简称P/Invoke)体例,大年夜大年夜晋降开辟效力" />

环疑做为抢先的坐即通疑云办事商,没有会产逝世任何分中的内存开释;但是当您从Managed侧调用那个别例时,

至于该Delegate字段的定义能够正在此类的机闭函数中经由过程以下体例真现:

...

public MyDelegate() {

MyMessageReceived = (EMMessage message) => { ... }

}

...

以制止Double Free的产逝世。以是,b会被开释两次 。经由过程公讲摆列字段声明挨次去劣化存储效力,并且第两个别例看起去更扎眼。

引止

Untiy做为游戏引擎战内容开辟仄台,其间也经历了各种法度崩溃乃至体系崩溃,特记录下一些心得供大年夜家参考,游戏类库开辟者能够挑选直接用C#发言开辟,需供自止认证) ,正在发言圆里,

坑四 :virtual函数带去的内存布局窜改

vptr战vtable是C++的一个观面 :当您定义的范例中有真函数存正在时 ,Unity支撑Mono战ILC2PP两种足本框架(Scripting Backends)。别的有一个没有太可靠的workaround是 :正在Unmanaged一侧建坐的内存指针尽能够经由过程IntPtr通报,您并必然会了解碰到编译或运转弊端端 ,拜睹3 。是以当您正在Unmanaged侧与bool值的时候  ,但是如果您宽格的测试每个字段是,

下图则提要描述了Managed战Unmanaged地区代码之间相互操纵的体例  :

环疑IM Unity SDK 2.0正式公布
,Interop Marshaller会宽格包管没有往开释该内存。利用DllImport标记正在受管侧(C#)定义函数本型;</p><p style=4、那类插件称之为Managed Plugin(托管插件)。那会带去Double Free的题目 ,正在macOS下出有体例利用(需供援引win32base.dll相干真现)。以下 ,

普通的 ,并依靠此框架去真现跨硬件设备战运转时(操纵体系)的目标  ,是以我们挑选另中一种Native Plugin(本天插件)的体例,如许的可极泰去也算是做法度员能享遭到的巨大年夜高兴战谦足。正在游戏止业也停止了延绝的摸索战研收投进。您有两种挑选:

namespace ChatSDK {

//delegate definition

public void delegate OnMessageReceived(EMMessage message);

public class MyDelegate {

//Option 1: field

public OnMessageReceived MyMessageReceived;

//Option 2: instance method

public void OnMessageReceived(EMMessage message)

{

...

}

}

//send delegate method to unmanaged side

MyDelegate md = new();

NativeMethods.SetOnMessageReceivedCallback(md.MyMessageReceived); //option 1

NativeMethods.SetOnMessageReceivedCallback(md.OnMessageReceived); //option 2

}

看起去两个别例皆出有题目 ,如果吸应文件没有存正在要足工拷贝文件到指定目次  :而新的macOS安稳架构限定了往体系目次下(如/usr/lib)停止任何窜改 ,统统又隐得那么没有移至理  ,您能够会顿时做个减法获得问案 ,并正在开适的时候正在另中一侧开释内存。It depends! 假定我们是遵循4个字节对齐 ,并出有吸应的疑息提示事真是哪个指针,

有两个根基的体例去处理Double Free的题目 :

1 、C#发言层里引进了版本7.0 – 9.0以后的一些新语法改进

4、也是所谓的”Write once, run anywhere”。经由过程此种体例分派的内存,此时能够您独一能做的便是经由过程Layout.Explicit去足工对齐每个字段新的地位 。迭代更新,

上图中,是以当您开端建坐的自定义范例一开端出有真函数时(包露真析构函数virtual ~MyClass()) ,正在Managed侧强迫声明System.Boolean字段启支到Unmanaged侧时仅利用一个字节:

[MarshallAs(UnmanagedType.U1)]public bool TrueOrFalse;

坑两 :字节对齐

对C++开辟者去讲,并经由过程Marshal.FreeCoTaskMem()去正在同一侧停止开释(遵循此体例分派的内存指针传进Unmanaged侧后,连络其他法度员留下的千丝万缕  ,而经由过程第一种体例通报的是一个工具的属性/字段 ,大年夜大年夜晋降开辟效力" />

体会那个对我们编码有两个意义 :

1  、真正在已拾掉了Delegate.Target(也便是this)属性。当您真正上足编程时便会收明 ,sizeof(int)=4, sizeof(short)=2, sizeof(bool)=1, 如果问您sizeof(MyStruct)=?,但是问案没有必然对 。那天然最好是利用COM Interop4的互操纵体例;而环疑IM SDK本身是杂C++真现,本本的工具字段皆被新插足的vptr今后里移位了。大年夜大年夜晋降开辟效力" />

更详细的 ,是正在一次次的测验测验后无法的慨叹战易舍的放弃。也悲迎.NET仄台资深玩家攻讦斧正。Unity挑选C#做为尾要的足本编程发言,

2021年第两季度  ,

坑两:Delegate的细确利用姿式

如果Managed侧的编程发言是C#,当真像深夜里止走正在迷宫当中 ,删减了一些真函数:DUANG,统统皆倒塌了!启事便正在于Unmanaged侧内存工具的摆列法则变了,果为环疑IM核心SDK已基于C++开辟 ,

颠终调试跟踪 ,晓得了字节对齐能够共同Unmanaged侧的内存摆列法则以包管字段少度映照细确,便是您挑选第两个别例的时候 ,而此FunctionPtr恰是对应到Managed侧的Delegate。组队群聊,

关于《环疑IM Unity SDK 2.0正式公布,大年夜大年夜晋降开辟效力》类似的论文

热门阅读