理解一块C#代码

理解一块C#代码,第1张

概述我已经在c#编写了一段时间,但是我遇到了一些对我来说没有任何意义的代码.它看起来像下面这样: [DllImport(DllName, SetLastError = true, CallingConvention=CallingConvention.Cdecl)]static extern byte QLIB_UploadCEFS_File(UInt32 handle, string s @H_404_4@ 我已经在c#编写了一段时间,但是我遇到了一些对我来说没有任何意义的代码.它看起来像下面这样:

[Dllimport(Dllname,SetLastError = true,CallingConvention=CallingConvention.Cdecl)]static extern byte QliB_UploadCEFS_file(UInt32 handle,string sfilename,string sPartitionfilename);

我不知道如何解释这段代码.任何人都可以解释一下他们在这里想要达到的目标吗?

@H_404_4@解决方法 这是 P/Invoke声明.它声明了一个在该模块外部的函数,该函数在非托管DLL中实现.

Dllimport属性指定此实例中非托管DLL的名称,Dllname.在这个例子中,Dllimport属性的其他属性指定调用约定,并且该函数设置Win32最后一个错误变量.

函数声明本身指定非托管函数的签名.在这种情况下,参数表示该函数具有以下非托管声明:

unsigned char QliB_UploadCEFS_file(    unsigned int handle,const char *sfilename,const char *sPartitionfilename);

从调用函数的托管代码的角度来看,它就像任何其他函数一样.您可以调用它来传递问题中代码中指定的参数.

对于它的价值,我怀疑声明是不正确的.第一个参数是句柄,它们几乎总是指针大小.因此,虽然代码可能在32位下很好,但很可能会在64位以下打破.我希望看到第一个参数声明为IntPtr.当然,这是推测,因为我看不到实际的非托管函数声明.

@H_404_4@ @H_404_4@ @H_404_4@ @H_404_4@ 总结

以上是内存溢出为你收集整理的理解一块C#代码全部内容,希望文章能够帮你解决理解一块C#代码所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1220596.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存