導航:首頁 > 編程語言 > javajna調用c

javajna調用c

發布時間:2022-05-07 03:25:20

java用JNA調用c/c++的dll介面時,怎麼獲取介面中的out參數,例如:

java通過jna調用c++/c的.dll/.so庫介面
1。通過jni技術可以實現java調用so文件(這個自己實現了,以前的日誌也有,並沒有用jni來調用dll文件,原因是自己對這個不熟啊,不知道怎樣生成dll文件。。。。)。
2.使用jni的時候會顯得很繁瑣,因為要有許多函數的聲明要相同,jna技術就可以省卻這一點,拿到一個現成的dll,只要知道函數聲明,就可以直接調用了(用jna還未實驗調用so文件)。

下面介紹一下jna調用dll的過程。

1.導入jna.jar包,這個就不說了,下載一個就可以了。
2.主要代碼:
import com.sun.jna.Library;import com.sun.jna.Native;public interface Net extends Library { Net lib = (Net)Native.loadLibrary("NetDvr2", Net.class); int NETDVR_startup();}//調用public class TestJna { public static void main(String[] args) { System.out.println(Net.lib.NETDVR_startup()); }}NetDvr2.dll放在工程的根目錄下邊即可。

可能出現的錯誤:
java.lang.UnsatisfiedLinkError: Unable to load library 'NetDvr2': ???????¨
原因是NetDvr2.dll(或者NetDvr2.so)還依賴於其他幾個dll(so)文件,把他們一起拷到該java工程的根目錄就行了。
查看一個dll文件所依賴的dll文件可以用Depends.exe。

㈡ 用Java怎麼調用C語言已經編寫好的DLL

1. 編寫範例文檔 public class TestNative { private native static int Max(int a,int b); public static void main(String[] args) { System.out.println(Max(4,5)); } static { System.loadLibrary("VCdll"); } } 其中 LoadLibrary中的DLL文件名稱可以隨便定.只要做好的動態鏈接庫改名成這個字元串就可以了.而native函數的來源就是該動態鏈接庫. 2. 做好該步准備以後,用javac TestNative.java生成TestNative.class. 檢驗語法. 3. 語法檢查通過以後,用javah TestNative生成TestNative.h的C++頭文件. 4. 用VC++6.0創建dll文件: <1>msdev->new->project->win32 Dynamic-Link Library <2>Enter project name (e.g. VCdll) <3>choose "An empty DLL project"->finish <4>將3生成的TestNative.h和jdk下的jni.h和jni_md.h加入到工程中去 <5>Create a c++ file, implements the native method. as follows: //TestNative.cpp #include "TestNative.h" JNIEXPORT jint JNICALL Java_TestNative_Max (JNIEnv * a, jclass b, jint x, jint y) { return x > y ? x : y; } 備注: A 其中的jni.h通常在 jdk\include\ 可以先拷貝到VC安裝目錄下的include目錄下.一勞永逸,以後可以方便使用JNI技術. B 全部的數據類型需要考慮Java和VC的介面問題.用jint jstring 等. C 函數名稱和自動生成的.h文件中規定的一致.命名規則是: Java_使用類_方法名 6. 全編譯一下VC++工程. 如果沒有出錯,則此時生成動態鏈接庫成功. 把動態鏈接庫VCdll.dll拷貝到TestNative.java所在的目錄上. 7.運行java TestNative. OK :-)
參考資料: http://hi..com/dinguangx/blog/item/196560017e40e2031c95832f.html

㈢ java怎麼引用c

Java調用C語言程序時,主要是涉及到操作系統底層的事件。這種時間Java無法處理,例如用戶上傳一個視頻文件,需要後台給視頻加上水印,或者後台分離視頻流和音頻流。只能通過調用C語言處理。
使用Java如何去調用C語言的介面呢?使用Java的JNI技術。
具體調用步驟如下:
1.首先創建Java文件 HelloJni.java ,並創建native方法。
2.編譯Java文件並生成java頭文件。
3.創建C語言文件,HelloWorld.c。
4.生成動態鏈接庫文件 libhello.so。
5.設置動態鏈接庫文件的目錄。
6.把剛才生成的so文件拷貝到/home/lib下,然後執行class文件。

㈣ 怎樣在linux環境下使用java調用C++動態鏈接庫時將圖片位元組流傳到C++方法的void*參數中(使用的JNA)

的(在WINDOWS平台上是DLL文件形式,在UNIX機器上是SO文件形式)。
如下是詳細講解:

1、JAVA中所需要做的工作
在JAVA程序中,首先需要在類中聲明所調用的庫名稱,如下:
static {
System.loadLibrary(「goodluck」);
}
在這里,庫的擴展名字可以不用寫出來,究竟是DLL還是SO,由系統自己判斷。
還需要對將要調用的方法做本地聲明,關鍵字為native。並且只需要聲明,而不需要具體實現。如下:
public native static void set(int i);
public native static int get();
然後編譯該JAVA程序文件,生成CLASS,再用JAVAH命令,JNI就會生成C/C++的頭文件。
例如程序TestDll.java,內容為:
public class TestDll
{
static
{
System.loadLibrary("goodluck");
}
public native static int get();
public native static void set(int i);
public static void main(String[] args)
{
TestDll test = new TestDll();
test.set(10);
System.out.println(test.get());
}
}
用javac TestDll.java編譯它,會生成TestDll.class。
再用javah TestDll,則會在當前目錄下生成TestDll.h文件,這個文件需要被C/C++程序調用來生成所需的庫文件。

2、C/C++中所需要做的工作
對於已生成的.h頭文件,C/C++所需要做的,就是把它的各個方法具體的實現。然後編譯連接成庫文件即可。再把庫文件拷貝到JAVA程序的路徑下面,就可以用JAVA調用C/C++所實現的功能了。
接上例子。我們先看一下TestDll.h文件的內容:
/* DO NOT EDIT THIS FILE - it is machine generated */
#include
/* Header for class TestDll */
#ifndef _Included_TestDll
#define _Included_TestDll
#ifdef __cplusplus
extern "C" {
#endif
JNIEXPORT jint JNICALL Java_TestDll_get (JNIEnv *, jclass);
JNIEXPORT void JNICALL Java_TestDll_set (JNIEnv *, jclass, jint);
#ifdef __cplusplus
}
#endif
#endif
在具體實現的時候,我們只關心兩個函數原型
JNIEXPORT jint JNICALL Java_TestDll_get (JNIEnv *, jclass);

JNIEXPORT void JNICALL Java_TestDll_set (JNIEnv *, jclass, jint);
這里JNIEXPORT和JNICALL都是JNI的關鍵字,表示此函數是要被JNI調用的。而jint是以JNI為中介使JAVA的int類型與本地的int溝通的一種類型,我們可以視而不見,就當做int使用。函數的名稱是JAVA_再加上java程序的package路徑再加函數名組成的。參數中,我們也只需要關心在JAVA程序中存在的參數,至於JNIEnv*和jclass我們一般沒有必要去碰它。
下面我們用TestDll.cpp文件具體實現這兩個函數:
#include "TestDll.h"
int i = 0;
JNIEXPORT jint JNICALL Java_TestDll_get (JNIEnv *, jclass)
{
return i;
}
JNIEXPORT void JNICALL Java_TestDll_set (JNIEnv *, jclass, jint j)
{
i = j;
}
編譯連接成庫文件,本例是在WINDOWS下做的,生成的是DLL文件。並且名稱要與JAVA中需要調用的一致,這里就是goodluck.dll
把goodluck.dll拷貝到TestDll.class的目錄下,java TestDll運行它,就可以觀察到結果了。
3、你想保存一個"\sample\myfile.txt"到變數str中,原本就要寫成

㈤ java用jna調用C語言dll介面中的回調函數怎麼寫

簡單的你會寫,那就好辦,直接上代碼

{

{
/**
*登錄回調
*/
voidinvoke(StringuserId,longretCode,StringretMsg);
}

/**
*注冊一個登錄回調方法.此方法是dll提供的
*/
voidRegisterLoginReply(LoginReplyloginReply);

}

/**
*實現登錄回調方法
*/
.LoginReply{
@Override
publicvoidinvoke(StringuserId,longretCode,StringretMsg){
log.info("登錄回調方法:{},{},{}",userId,retCode,retMsg);
}
}

//設置登錄回調
api.RegisterLoginReply(loginReplyCallBack);

㈥ jna如何調用c

通過 jni 中轉。

參考我另一個回答:

http://..com/question/175483166073554524.html?oldq=1

㈦ JNA調用C的DLL,如何取回當初傳入的字元指針的修改值

C代碼extern "C" int _declspec(dllexport) getXMLResult(char *result){result = "abcd";return 20;}這個函數的目的是傳入字元指針,在函數內容修改指針指向的字元串內容java代碼public class JNATest {
// This is the standard, stable way of mapping, which supports extensive
// customization and mapping of Java to native types.
public interface CLibrary extends Library {
CLibrary INSTANCE = (CLibrary)
Native.loadLibrary("TestDLL.dll", CLibrary.class);
//函數聲明byte[]和String都試過,都不行,改變不了傳遞進去的字元串
int getXMLResult(byte[] result);}/*** @param args*/public static void main(String[] args) {
// TODO Auto-generated method stub
System.out.println("begin");
//WString s = new WString("Hello, World");
//System.out.println("s="+s.toString());
byte[] c = {'a','a','a','a'};
System.out.println("c="+Native.toString(c));
//ByteByReference[] iref = new ByteByReference[4];
int i = CLibrary.INSTANCE.getXMLResult(c);
System.out.println("i="+i);
System.out.println("c="+Native.toString(c));
//System.out.println("s="+s.toString());
System.out.println("end");}}Java中byte[] c初始化,調用DLL中函數,但byte[] c的值沒有被修改。
===============================================================

㈧ java用jna調用C的時候怎麼獲取C中輸出參數

你先在C環境下調用client_sdk_send_return()函數進行測試,確保不是此函數本身導致的問題。
如果不是,再檢查包裝函數時是否參數傳遞有誤。

㈨ JNA 調用c++函數的出錯,java能載入庫,但是找不到c++寫的函數

調用C++編譯的代碼能調用到庫但是找不到函數,應該是因為C++編譯器會破壞函數的名稱。

對此,一般網上能查到兩種方法解決:

  1. 用extern C ,功能是將部分代碼用C編譯器進行編譯,因為 C編譯器不會改變函數的函數名,Java中就可以用代碼中的函數名調用了。

  2. 用def模板

注1:這里說的方法你需要自己去查一下,別人的文章會寫得比較清楚,看完整的文章能學到更多。

注2: 對於C和C++編譯器對函數名的影響,這里和你說一下如何查看:你想看看C++編譯器編譯的DLL的方法名可以用depends反編譯程序,把dll拖進depends程序窗口,左邊會有依賴樹,點擊最頂端你的「庫名.dll」,右邊就能看到dll中函數被C++編譯之後的名字。如下圖:

  1. 用C編譯的DLL:

閱讀全文

與javajna調用c相關的資料

熱點內容
一天一圖學會python可視化 瀏覽:307
魔獸編輯文本命令串 瀏覽:495
android中view繪制 瀏覽:796
安卓機內存刪除怎麼恢復 瀏覽:329
Qt環境的編譯軟體放到linux 瀏覽:212
聯創列印系統怎麼連接伺服器 瀏覽:935
杭州行政命令 瀏覽:160
如何查找伺服器日誌 瀏覽:801
加密的鑰匙扣怎麼寫 瀏覽:579
文件夾更新不了怎麼辦 瀏覽:475
壓縮機指示燈亮是什麼原因 瀏覽:956
什麼app訂酒店半價 瀏覽:765
中老年解壓神器 瀏覽:243
訊飛語音ttsandroid 瀏覽:468
腰椎壓縮性骨折術後能坐車嗎 瀏覽:507
python類裝飾器參數 瀏覽:348
均線pdf微盤 瀏覽:791
女生喜歡玩的解壓游戲 瀏覽:442
支付寶暗號加密操作 瀏覽:134
柯潔在哪個app下圍棋 瀏覽:751