十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
這篇文章主要講解了“Java CPP的坑有哪些”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“Java CPP的坑有哪些”吧!

System.load
//System.load 參數(shù)必須為庫文件的絕對路徑,可以是任意路徑,例如:
System.load("C:\\Documents and Settings\\TestJNI.dll"); //Windows
System.load("/usr/lib/TestJNI.so"); //LinuxSystem.loadLibrary
//System.loadLibrary 參數(shù)為庫文件名,不包含庫文件的擴(kuò)展名。
System.loadLibrary ("TestJNI"); //加載Windows下的TestJNI.dll本地庫
System.loadLibrary ("TestJNI"); //加載Linux下的libTestJNI.so本地庫
//注意:TestJNI.dll 或 libTestJNI.so 必須是在JVM屬性java.library.path所指向的路徑中。1231234GlobalFunction.getSingleton().loadJNILibrary("zlprint");loadJNILibrary
這個方法是自動從classpath或者jar包中尋找 zlprint.dll 或者 zlprint.so(具體根據(jù)OS系統(tǒng)平臺決定)
重復(fù)加載相同的dll會報錯哦!
loadJNILibrary要區(qū)分x86和x64,假設(shè)你有相同的兩個zlprint.dll,請?jiān)谇懊婕由夏夸浵薅Q,比如:windows-x86_64/zlprint12執(zhí)行這些命令行的時候需要在Visual Studio 20XX的命令提示符下運(yùn)行
$ javac -cp javacpp.jar NativeLibrary.java
$ java -jar javacpp.jar NativeLibrary
$ java -cp javacpp.jar NativeLibrary
因?yàn)樽詈笠恍忻顣{(diào)用VS的運(yùn)行環(huán)境編譯器cl.exe,不是在Visual Studio x64 Win64 Command Prompt (2010)命令中執(zhí)行就找不到這玩意兒!
如果你寫的xxx.java文件中包含了package信息,編譯的時候應(yīng)該把xxx.class文件放在package目錄下才能夠編譯(這是java常識)
JavaCPP中的注解annotation都是針對c++文件生成而言,跟java文件本身沒有任何毛關(guān)系!
作用是為了配置生成的cpp代碼而存在
@Platform(include=“PrintLib.h”,link =“D:/javacpp-bin/zlprint”)
頭文件包含可以這樣:include={“PrintLib.h”,“string.h”}
感謝各位的閱讀,以上就是“Java CPP的坑有哪些”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對Java CPP的坑有哪些這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!