java調用相互依賴的dll的處理方法
一、問題描述
最近在做一個功能時遇到java需要調用dll,并且dll有依賴關系,之前都是單獨調用一個,其實調用dll的都是模板代碼,本身沒有太高的難度,主要是相互依賴的還是第一次碰見,特此記錄一下并分享給需要的朋友參考。
二、處理辦法
其中A是dll方法的入口,A依賴B,C,D,E,F(xiàn),G五個dll,先定義接口繼承StdCallLibrary ,編寫加載各個dll的模板代碼,需要依賴的都全部加載進來,我這兒是A依賴了B,C,D,E,F(xiàn),G六個dll,所以我這里共寫了六個接口,來分別加載不同的dll,主要是因為StdCallLibrary不支持加載多個dll,如果支持的話就不用寫多個了,廢話不多說直接上代碼:
2.1 類定義
import com.sun.jna.Native;
import com.sun.jna.win32.StdCallLibrary;
/**
*
* ClassName: DllLoadClass <br/>
* Function: TODO ADD FUNCTION. <br/>
* Reason: TODO ADD REASON(可選). <br/>
* date: 2022年1月27日 下午5:08:21 <br/>
*
* @author 行則將至
* @version
*/
public class DllLoadClass {
/**
*
* ClassName: A <br/>
* Function: TODO 加載A. <br/>
* Reason: TODO ADD REASON(可選). <br/>
* date: 2022年1月27日 下午5:08:58 <br/>
*
* @author 行則將至
* @version DllLoadClass
*/
public interface A extends StdCallLibrary {
String dllName = "dllv2/A";
A INSTANCE = Native.load(dllName,A.class);
public String a(String inString);
}
/**
*
* ClassName: B <br/>
* Function: TODO 加載B. <br/>
* Reason: TODO ADD REASON(可選). <br/>
* date: 2022年1月27日 下午5:09:27 <br/>
*
* @author 行則將至
* @version DllLoadClass
*/
public interface B extends StdCallLibrary {
String dllName = "dllv2/B64";
B INSTANCE = Native.load(dllName,B.class);
}
/**
*
* ClassName: C <br/>
* Function: TODO 加載C. <br/>
* Reason: TODO ADD REASON(可選). <br/>
* date: 2022年1月27日 下午5:09:41 <br/>
*
* @author 行則將至
* @version DllLoadClass
*/
public interface C extends StdCallLibrary {
String dllName = "dllv2/C64";
C INSTANCE = Native.load(dllName,C.class);
}
/**
*
* ClassName: D <br/>
* Function: TODO 加載D. <br/>
* Reason: TODO ADD REASON(可選). <br/>
* date: 2022年1月27日 下午5:09:50 <br/>
*
* @author 行則將至
* @version DllLoadClass
*/
public interface D extends StdCallLibrary {
String dllName = "dllv2/D64";
D INSTANCE = Native.load(dllName,D.class);
}
/**
*
* ClassName: E <br/>
* Function: TODO 加載E. <br/>
* Reason: TODO ADD REASON(可選). <br/>
* date: 2022年1月27日 下午5:10:37 <br/>
*
* @author 行則將至
* @version DllLoadClass
*/
public interface E extends StdCallLibrary {
String dllName = "dllv2/E64";
E INSTANCE = Native.load(dllName,E.class);
}
/**
*
* ClassName: F <br/>
* Function: TODO 加載F. <br/>
* Reason: TODO ADD REASON(可選). <br/>
* date: 2022年1月27日 下午5:10:01 <br/>
*
* @author 行則將至
* @version DllLoadClass
*/
public interface F extends StdCallLibrary {
String dllName = "dllv2/F64";
F INSTANCE = Native.load(dllName,F.class);
}
/**
*
* ClassName: G <br/>
* Function: TODO 加載G. <br/>
* Reason: TODO ADD REASON(可選). <br/>
* date: 2022年1月27日 下午5:10:10 <br/>
*
* @author 行則將至
* @version DllLoadClass
*/
public interface G extends StdCallLibrary {
String dllName = "dllv2/G64";
G INSTANCE = Native.load(dllName,G.class);
}
}
2.2 調用
上邊雖然是定義出來了,那么怎么調用或者使用呢?調用其實也很簡單,都定義出來了之后,其實就是需要咱們把依賴都加載進來即可,咱們仍然是直接上代碼:
public class Test {
@SuppressWarnings("unused")
public static void main(String[] args) {
B b = DllLoadClass.B.INSTANCE;
C c = DllLoadClass.C.INSTANCE;
D d = DllLoadClass.D.INSTANCE;
F f = DllLoadClass.F.INSTANCE;
G g = DllLoadClass.G.INSTANCE;
A a = DllLoadClass.A.INSTANCE;
String result = a.a("");
}
}
原理就是調用一下成員變量,讓其加載進來即可。
三、結語
道阻且長,行則將至,行而不輟,未來可期,加油。
到此這篇關于java調用相互依賴的dll的處理方法的文章就介紹到這了,更多相關java相互依賴的dll內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Spring?Aop+Redis實現(xiàn)優(yōu)雅記錄接口調用情況
通常情況下,開發(fā)完一個接口,無論是在測試階段還是生產上線,我們都需要對接口的執(zhí)行情況做一個監(jiān)控,所以本文為大家整理了Spring統(tǒng)計接口調用的多種方法,希望對大家有所幫助2023-06-06
eclipse+myeclipse 環(huán)境配置方法
eclipse+myeclipse配置環(huán)境2009-07-07
通過實例了解java checked和unchecked異常
這篇文章主要介紹了通過實例了解checked和unchecked異常,Java異常分為兩種類型,checked異常和unchecked異常,另一種叫法是異常和錯誤。下面小編就帶大家來一起學習一下吧2019-06-06
Java String 和 new String()的比較與區(qū)別
這篇文章主要介紹了Java String 和 new String()的區(qū)別的相關資料,需要的朋友可以參考下2017-04-04
springboot+thymeleaf整合阿里云OOS對象存儲圖片的實現(xiàn)
本文主要介紹了springboot+thymeleaf整合阿里云OOS對象存儲圖片的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-05-05
Java多線程并發(fā)的指令重排序問題及volatile寫屏障原理詳解
這篇文章主要介紹了Java多線程并發(fā)的指令重排序問題及volatile寫屏障原理詳解,指令重排序是編譯器或處理器為了提高性能而對指令執(zhí)行順序進行重新排列的優(yōu)化技術,需要的朋友可以參考下2024-01-01
java線程并發(fā)countdownlatch類使用示例
javar的CountDownLatch是個計數(shù)器,它有一個初始數(shù),等待這個計數(shù)器的線程必須等到計數(shù)器倒數(shù)到零時才可繼續(xù)。2014-01-01

