因為現在的項目使用的是 anycpu 在 x86 的設備使用的是x86,在x64使用的是x64,但是對于非托管代碼,必須要在x64使用x64的dll,在x86使用x86的dll。在c++沒有和c#一樣的 anycpu 所以需要在項目運行在x86的時候加載x86的dll。 本文告訴大家如何在代碼引用不同的dll。
使用宏
最簡單的方法是編譯兩個版本,編譯多個版本可以點擊配置管理器,然后創建x86和x64,然后版本添加宏,這樣就可以判斷宏來使用不同的dll
點擊活動解決方案平臺,然后點擊新建
選擇項目屬性,點擊生成,就可以添加不同的宏
于是在后臺代碼可以這樣寫
1
2
3
4
5
6
7
|
#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 ,那么可以使用兩個不同函數
1
2
3
4
5
6
|
[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); |
然后再寫一個函數
1
2
3
4
5
6
7
8
9
|
public int hfwzsnhzhpbbzbn( int txcuiwkjvwu, int hhmzfadnhexkmr) { if (environment.is64bitprocess) { return hfwzsnhzhpbbzbn64(txcuiwkjvwu, hhmzfadnhexkmr); } return hfwzsnhzhpbbzbn32(txcuiwkjvwu, hhmzfadnhexkmr); } |
這樣就不需要在使用的時候判斷當前使用的是哪個,但是如果dll多了,一個dll都需要寫三次,看起來代碼還是很爛
設置查找的文件
實際上好多人都覺得,應用程序首先是從運行的目錄開始查找dll,如果找不到,就去gac查找,如果還是找不到,就去system查找。實際上這句話是不對的,在沒有設置默認查找的文件的時候就是這樣,但是軟件是可以設置查找文件。
設置的方法使用使用這個dll,請看下面
1
2
3
4
5
6
7
8
|
public int hfwzsnhzhpbbzbn( int txcuiwkjvwu, int hhmzfadnhexkmr) { if (environment.is64bitprocess) { return hfwzsnhzhpbbzbn64(txcuiwkjvwu, hhmzfadnhexkmr); } return hfwzsnhzhpbbzbn32(txcuiwkjvwu, hhmzfadnhexkmr); } |
需要先把 x86 的 dll 放在程序的 x86文件夾,當然對于x64的大家也知道放哪里。
然后在程序運行的時候使用下面的代碼
1
2
|
[dllimport( "kernel32.dll" , charset = charset.auto, setlasterror = true )] private static extern bool setdlldirectory( string path); |
這樣就可以直接寫一個函數,最后的方法是我推薦的。
但是存在一些特殊的文件,他不能放在x86文件夾,所以就需要使用下面的代碼特別加載
1
2
3
|
var path = path.getdirectoryname(assembly.getentryassembly().location); path = path.combine(path, environment.is64bitprocess ? "x64" : "x86" ); setdlldirectory(path); |
查看了項目的代碼才看到,實際上還有一個方法,就是在運行的時候,如果當前運行的是x86的,就從x86文件夾復制dll出來,這個方法是速度最慢的。
總結
以上所述是小編給大家介紹的c# 在項目中引用x86 x64的非托管代碼的方法,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!
原文鏈接:https://www.tuicool.com/articles/nQ3uAzI