因为现在的项目使用的是 AnyCpu 在 x86 的设备使用的是x86,在x64使用的是x64,但是对于非托管代码,必须要在x64使用x64的dll,在x86使用x86的dll。在C++没有和C#一样的 AnyCpu 所以需要在项目运行在x86的时候加载x86的dll。 本文告诉大家如何在代码引用不同的dll。
使用宏
最简单的方法是编译两个版本,编译多个版本可以点击配置管理器,然后创建x86和x64,然后版本添加宏,这样就可以判断宏来使用不同的dll
点击活动解决方案平台,然后点击新建
选择项目属性,点击生成,就可以添加不同的宏
于是在后台代码可以这样写
#if x86 public const string DLL_FILE_NAME = "SvkiqauhKvdhrureh32.dll"; #else public const string DLL_FILE_NAME = "SvkiqauhKvdhrureh64.dll"; #endif [DllImport(DLL_FILE_NAME, EntryPoint = "HfwzsnHzhpbbzbn", CallingConvention = CallingConvention.Cdecl)] private static extern int HfwzsnHzhpbbzbn(int var1, int var2);
可以看到这个方法如果有很多个 dll 那么需要写很多路径
多个函数
实际上如果已经有两个dll ,那么可以使用两个不同函数
[DllImport("SvkiqauhKvdhrureh32.dll", EntryPoint = "HfwzsnHzhpbbzbn", CallingConvention = CallingConvention.Cdecl)] private static extern int HfwzsnHzhpbbzbn32(int txcuiwKjvwu, int hhmzfadnHexkmr); [DllImport("SvkiqauhKvdhrureh64.dll", EntryPoint = "HfwzsnHzhpbbzbn", CallingConvention = CallingConvention.Cdecl)] private static extern int HfwzsnHzhpbbzbn64(int txcuiwKjvwu, int hhmzfadnHexkmr);
然后再写一个函数
public int HfwzsnHzhpbbzbn(int txcuiwKjvwu, int hhmzfadnHexkmr) { if (Environment.Is64BitProcess) { return HfwzsnHzhpbbzbn64(txcuiwKjvwu, hhmzfadnHexkmr); } return HfwzsnHzhpbbzbn32(txcuiwKjvwu, hhmzfadnHexkmr); }
这样就不需要在使用的时候判断当前使用的是哪个,但是如果dll多了,一个dll都需要写三次,看起来代码还是很烂
设置查找的文件
实际上好多人都觉得,应用程序首先是从运行的目录开始查找dll,如果找不到,就去GAC查找,如果还是找不到,就去System查找。实际上这句话是不对的,在没有设置默认查找的文件的时候就是这样,但是软件是可以设置查找文件。
设置的方法使用使用这个dll,请看下面
public int HfwzsnHzhpbbzbn(int txcuiwKjvwu, int hhmzfadnHexkmr) { if (Environment.Is64BitProcess) { return HfwzsnHzhpbbzbn64(txcuiwKjvwu, hhmzfadnHexkmr); } return HfwzsnHzhpbbzbn32(txcuiwKjvwu, hhmzfadnHexkmr); }
需要先把 x86 的 dll 放在程序的 x86文件夹,当然对于x64的大家也知道放哪里。
然后在程序运行的时候使用下面的代码
[DllImport("kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)] private static extern bool SetDllDirectory(string path);
这样就可以直接写一个函数,最后的方法是我推荐的。
但是存在一些特殊的文件,他不能放在x86文件夹,所以就需要使用下面的代码特别加载
var path = Path.GetDirectoryName(Assembly.GetEntryAssembly().Location); path = Path.Combine(path, Environment.Is64BitProcess ? "x64" : "x86"); SetDllDirectory(path);
查看了项目的代码才看到,实际上还有一个方法,就是在运行的时候,如果当前运行的是x86的,就从x86文件夹复制dll出来,这个方法是速度最慢的。
总结
以上所述是小编给大家介绍的C# 在项目中引用x86 x64的非托管代码的方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
项目管理 & 代码托管 Github [free to $] Codebase [$] Bitbucket [free to $] Unfuddle [$] Assembla [free to $]
本文向大家介绍.NET中托管和非托管代码之间的区别,包括了.NET中托管和非托管代码之间的区别的使用技巧和注意事项,需要的朋友参考一下 .NET Framework具有CLR(公共语言运行时),可以执行用.NET语言编写的代码。CLR管理内存需求,安全性,代码优化,特定于平台的转换等。在非托管代码的情况下,不存在CLR,并且代码由操作系统直接执行。 以下是托管代码和非托管代码之间的一些重要区别。
好吧,问题是:当我运行C#代码时,对System.LoadLibrary(...)的java调用失败,我得到一个“UnsatisfiedLinkError:Can't load absolute_path_to_my_dll.dll”。绝对路径是正常的,并且dll存在。 有人帮忙吗?提前道谢。 编辑%1 现在,我在托管dll中编译java代码,该dll可以导入到.NET项目中。首先,我将java项
是否可以在使用关键字创建的类中获取CDIBean的实例?我们目前正在对一个旧的应用程序进行一些增强,每次我们在应用程序中对CDI单例bean进行编程查找时,都会得到一个ContextNotActiveException。 获取参考的代码: BeanManager支持。JAVA
问题内容: 自从Go 1.5发布以来,我开始着眼于如何将其集成到我现有的项目中。 该项目的代码库完全用C编写,可以低级访问硬件和其他有趣的东西。但是,某些较高层次的东西很繁琐,我想开始用较高层次的语言(Go)编写它们 我可以通过C程序调用Go代码吗?我安装了Go 1.5,它添加了(https://golang.org/s/execmodes),我正试图开始工作。 但是,我似乎无法让Go生成适当的头
本章介绍如何在GitHub上创建一个新项目,包括创建版本库及为项目设计主页等。 3.1. 创建新项目 3.2. 操作版本库 3.3. 公钥认证管理 3.4. 版本库钩子扩展 3.5. 建立主页