.net – 在Win32/COM方法上调用PInvoke时,通常有一个明显的性能下降吗?

前端之家收集整理的这篇文章主要介绍了.net – 在Win32/COM方法上调用PInvoke时,通常有一个明显的性能下降吗?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想知道有没有人有一个体面的解释或概述在使用DLLImport / PInvoke在Win32方法从负责的网络代码

我打算利用各种Win32方法,并希望更好地了解这样做的负面影响。

谢谢,

布莱恩。

根据 MSDN – Calling Native Functions from Managed Code

PInvoke has an overhead of between 10 and 30 x86 instructions per call. In addition to this fixed cost,marshaling creates additional overhead. There is no marshaling cost between blittable types that have the same representation in managed and unmanaged code. For example,there is no cost to translate between int and Int32.

根据我的经验,当P /调用本机功能时,绝对会有一个开销,但是通常性能下降并不值得担心。封送费用是要记住的。如果您正在传递大型结构,字符串等,那么性能成本将很快显现。

对于非常频繁调用的P /调用函数,您可能需要考虑将[SuppressUnmanagedCodeSecurity]添加到P / Invoke函数定义(参见MSDN – SuppressUnmanagedCodeSecurityAttribute)。这将使运行时停止堆栈步行,以确保调用者具有非管理代码权限。当然,请确保您在添加属性之前了解安全性后果。

原文链接:https://www.f2er.com/windows/373153.html

猜你在找的Windows相关文章