您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)java調(diào)用相互依賴的dll的處理方法是什么,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
最近在做一個功能時遇到j(luò)ava需要調(diào)用dll,并且dll有依賴關(guān)系,之前都是單獨(dú)調(diào)用一個,其實(shí)調(diào)用dll的都是模板代碼,本身沒有太高的難度,主要是相互依賴的還是第一次碰見,特此記錄一下并分享給需要的朋友參考。
其中A是dll方法的入口,A依賴B,C,D,E,F(xiàn),G五個dll,先定義接口繼承StdCallLibrary ,編寫加載各個dll的模板代碼,需要依賴的都全部加載進(jìn)來,我這兒是A依賴了B,C,D,E,F(xiàn),G六個dll,所以我這里共寫了六個接口,來分別加載不同的dll,主要是因為StdCallLibrary不支持加載多個dll,如果支持的話就不用寫多個了,廢話不多說直接上代碼:
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); } }
上邊雖然是定義出來了,那么怎么調(diào)用或者使用呢?調(diào)用其實(shí)也很簡單,都定義出來了之后,其實(shí)就是需要咱們把依賴都加載進(jìn)來即可,咱們?nèi)匀皇侵苯由洗a:
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(""); } }
原理就是調(diào)用一下成員變量,讓其加載進(jìn)來即可。
關(guān)于java調(diào)用相互依賴的dll的處理方法是什么就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。