關於java如何用jna將位元組的信息

本文目錄一覽:

想知道java怎麼取com.sun.jna.ptr.ByteByReference裡面的數據。

我感覺你這樣設計有問題,JNI中java和C/C++的方法應該是保留java的方法名,當然這個不是重點,重點是你裡面的參數顯然不一致。ByteByReference是個對象類型,我們無法把它弄成一個指針類型,畢竟java沒有指針。我的建議是,pBuffer不要作為參數,用具體的類型。pBuffer作為全局變數在別的地方初始化,這樣不影響你在invoke方法裡面用pBuffer來獲取值。我這只是從你的描述簡單的看,具體的需求我也不太清楚你要做什麼,個人建議。

java中jna的問題

1、在VC下創建一個動態鏈接庫項目testJNA

2、在頭文件里聲明函數

C代碼 收藏代碼

extern “C” _declspec(dllexport) int add(int first, int second);

紅色字體部分是必須的,包括定義結構體時也需要。應該是說此函數是發布的。

3、在源碼里實現函數

C代碼 收藏代碼

int add(int first, int second) {

printf(“(c) test jna : %d + %d = %d”, first, second, first + second);

return first + second;

}

4、生成dll文件

5、定義一個表示鏈接庫的介面

介面TestJnaLib繼承自com.sun.jna.Library,此介面有一個實例

Java代碼 收藏代碼

TestJnaLib INSTANCE = (TestJnaLib)Native.loadLibrary(“testJNA.dll”, TestJnaLib.class);

此實例由jna通過反射自動生成。

6、定義對應dll里的方法

Java代碼 收藏代碼

int add(int first, int second);

7、調用本地方法

Java代碼 收藏代碼

TestJnaLib.INSTANCE.add(3, 5);

Jna回調Java方法:

1、在C語言部分定義帶回調函數的函數

C代碼 收藏代碼

extern “C” _declspec(dllexport) void methodWithCallback(int (*fp)(int left, int right), int left, int right);

紅色加粗部分是函數指針。

2、Java部分定義一個回調介面

必須繼承自com.sun.jna.Callback介面

Java代碼 收藏代碼

public interface FunCallBack extends Callback {

int invoke(int left, int right);

}

Invoke方法里的參數順序與C函數的對應

3、定義回調介面的實現

Java代碼 收藏代碼

public class CallbackFunImpl implements FunCallBack {

@Override

public int invoke(int left, int right) {

System.out.printf(“in java :%d + %d = %d\n”, left, right, left + right);

return left + right;

}

}

4、在表示鏈接庫實現的介面里定義要回調的本地函數

Java代碼 收藏代碼

void methodWithCallback(Callback callback, int left, int right);

本地函數的函數指針用Callback 介面替代。

5、調用帶函數指針的本地函數

Java代碼 收藏代碼

TestJnaLib.INSTANCE.methodWithCallback(new CallbackFunImpl(), 4, 6)

怎樣在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中,原本就要寫成

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/228839.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-10 12:08
下一篇 2024-12-10 12:08

相關推薦

  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • Java Bean載入過程

    Java Bean載入過程涉及到類載入器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean載入的過程。 一、類載入器 類載入器是Java虛擬機…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • 如何用Python寫愛心

    本文將會從多個方面闡述如何用Python語言來畫一個美麗的愛心圖案。 一、準備工作 在開始編寫程序之前,需要先理解一些編程基礎知識。首先是繪圖庫。Python有很多繪圖庫,常見的有…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字元串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字元串中是否存在多個指定字元: 一、字元串遍歷 字元串是Java編程中非常重要的一種數據類型。要判斷字元串中是否存在多個指定字元…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29
  • 如何用Python統計列表中各數據的方差和標準差

    本文將從多個方面闡述如何使用Python統計列表中各數據的方差和標準差, 並給出詳細的代碼示例。 一、什麼是方差和標準差 方差是衡量數據變異程度的統計指標,它是每個數據值和該數據值…

    編程 2025-04-29

發表回復

登錄後才能評論