當前位置:首頁 » 編程軟體 » java編譯dll

java編譯dll

發布時間: 2022-05-13 02:43:30

java程序能直接調用C寫好的dll文件嗎

JAVA通過JNI調用本地方法,而本地方法是以庫文件的形式存放的(在WINDOWS平台上是DLL文件形式,在UNIX機器上是SO文件形式)。通過調用本地的庫文件的內部方法,使JAVA可以實現和本地機器的緊密聯系,調用系統級的各介面方法。
簡單介紹及應用如下:
一、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++程序調用來生成所需的庫文件。

Ⅱ 如何解決java調dll報Unable to load library的錯誤

解決java調dll報Unable to load library的錯誤可以嘗試以下方法:
載入庫文件有兩個函數,System.load 和 System.loadLibrary。
當使用System.load時,需要輸入文件的全路徑,例如:System.load(「/tmp/test.so」);
當使用System.loadlibrary時是在系統的library 的目錄中需找復合條件的庫文件,可以使用-Djava.library.path=[path]參數,來指定Java程序載入庫文件的路徑,或者將庫文件(*.so,*.dll)復制到include的默認路徑,Linux一般是/usr/lib目錄下,當然你可以編輯/etc/ld.so.conf.d/下的文件,設定自己的庫查找路徑ldconfig -v|grep xxx看看有沒有你的動態庫。
Linux還要注意,使用System.loadLibrary(name)方法其中參數內容與Windows有區別,Linux中的的庫文件名為libname.so,Windows為name.dll。
在Windows中盡量使用Windows的C/C++編譯器生成dll文件,否則會出現問題。
不過具體問題還要具體對待!

Ⅲ java如何調用別人給的DLL文件

JAVA通過JNI調用本地方法,而本地方法是以庫文件的形式存放的(在WINDOWS平台上是DLL文件形式,在UNIX機器上是SO文件形式)。通過調用本地的庫文件的內部方法,使JAVA可以實現和本地機器的緊密聯系,調用系統級的各介面方法。
簡單介紹及應用如下:
一、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++程序調用來生成所需的庫文件。

Ⅳ java中怎麼編寫dll文件........最好舉個例子

你是指使用動態鏈接嗎?這個可以用java中的反射機製做到,但是java中是沒有動態鏈接庫這種東西的。如果你指的是java調用本地dll的話,是使用jni技術,dll也不是java編寫的。總是java是不可能編譯成為dll。有一種這種的方案,就是將java編譯的文件轉換為c#的,微軟有相應的工具,可以搜到,然後就可以打包成為dll了。

Ⅳ java 調用C寫的DLL

一、 生成C的頭文件
1. 編輯Main.java
public class Main
{
public native static int getStrNum(byte str[], int strLen);
}
2. 生成頭文件
按win + r打開「運行」窗口,輸入「cmd」,打開DOS控制台窗口。進入上面Main.java所在的目錄中,輸入:
javac Main.java
javah Main
兩條命令完成後會生成Main.h文件
二、 生成DLL
1. 新建空工程
在VS中新建工程:Win32 Console Application,取名「MakeDLL」,選擇空工程。新建後修改工程屬性:
(1) General中,將「Configuration Type」改為「Dynamic Library (.dll)」;
(2) C/C++的General中,將「Additional Include Directories」添加兩項:
「C:Program FilesJavajdk1.5.0_06include」
「C:Program FilesJavajdk1.5.0_06includewin32」
根據你安裝的JAVA路徑而設置,這是因為在C/C++編譯過程中要使用JAVA的jni.h等文件
2. 將上面生成的Main.h添加入工程
3. 新建一個新的文件main.cpp,代碼如下:
#include 』Main.h』
#include 』string.h』
JNIEXPORT jint JNICALL Java_Main_getStrNum(JNIEnv *env, jclass cls, jbyteArray str, jint strLen)
{
jbyte *buffer = (*env).GetByteArrayElements(str, 0);
buffer[strLen] = 』』; // 由於JAVA自動分配空間,需要傳進來字元串長度參數
jint len = strlen((char*)buffer);
return len;
}
4. 按F7編譯鏈接,生成MakeDLL.dll文件
三、 JAVA調用DLL
在JAVA中使用上面生成的DLL文件:
1. 將MakeDLL.dll復制到與使用DLL的JAVA文件相同的目錄下。
2. JAVA文件的源代碼:
public class Main
{
static
{
System.loadLibrary(』MakeDLL』);//載入資源文件MakeDLL.dll
}
public native static int getStrNum(byte str[], int strLen);
public static void main(String[] args)
{
Main instance = new Main();
String str = new String(』haha』);
int num = instance.getStrNum(str.getBytes(), str.length());
System.out.println(num);
}
}

Ⅵ java調用dll

調用printf()即可。
第一步是寫出對固有方法及它的自變數進行聲明的Java代碼:

class ShowMsgBox {
public static void main(String [] args) {
ShowMsgBox app = new ShowMsgBox();
app.ShowMessage( "Generated with JNI ");
}
private native void ShowMessage(String msg);
static {
System.loadLibrary( "MsgImpl ");
}
}

在固有方法聲明的後面,跟隨有一個static代碼塊,它會調用System.loadLibrary()(可在任何時候調用它,但這樣做更恰當)System.loadLibrary()將一個DLL載入內存,並建立同它的鏈接。DLL必須位於您的系統路徑,或者在包含了Java類文件的目錄中。根據具體的平台,JVM會自動添加適當的文件擴展名。

1. C頭文件生成器:javah
現在編譯您的Java源文件,並對編譯出來的.class文件運行javah。javah是在1.0版里提供的,但由於我們要使用Java 1.1 JNI,所以必須指定-jni參數:
javah -jni ShowMsgBox
javah會讀入類文件,並為每個固有方法聲明在C或C++頭文件里生成一個函數原型。下面是輸出結果——ShowMsgBox.h源文件(為符合本書的要求,稍微進行了一下修改):

/* DO NOT EDIT THIS FILE
- it is machine generated */
#include <jni.h>
/* Header for class ShowMsgBox */

#ifndef _Included_ShowMsgBox
#define _Included_ShowMsgBox
#ifdef __cplusplus
extern "C " {
#endif
/*
* Class: ShowMsgBox
* Method: ShowMessage
* Signature: (Ljava/lang/String;)V
*/
JNIEXPORT void JNICALL
Java_ShowMsgBox_ShowMessage
(JNIEnv *, jobject, jstring);

#ifdef __cplusplus
}
#endif
#endif

從「#ifdef_cplusplus」這個預處理引導命令可以看出,該文件既可由C編譯器編譯,亦可由C++編譯器編譯。第一個#include命令包括jni.h——一個頭文件,作用之一是定義在文件其餘部分用到的類型;JNIEXPORT和JNICALL是一些宏,它們進行了適當的擴充,以便與那些不同平台專用的引導命令配合;JNIEnv,jobject以及jstring則是JNI數據類型定義。

2. 名稱管理和函數簽名
JNI統一了固有方法的命名規則;這一點是非常重要的,因為它屬於虛擬機將Java調用與固有方法鏈接起來的機制的一部分。從根本上說,所有固有方法都要以一個「Java」起頭,後面跟隨Java方法的名字;下劃線字元則作為分隔符使用。若Java固有方法「過載」(即命名重復),那麼也把函數簽名追加到名字後面。在原型前面的注釋里,大家可看到固有的簽名。欲了解命名規則和固有方法簽名更詳細的情況,請參考相應的JNI文檔。

3. 實現自己的DLL
此時,我們要做的全部事情就是寫一個C或C++源文件,在其中包含由javah生成的頭文件;並實現固有方法;然後編譯它,生成一個動態鏈接庫。這一部分的工作是與平台有關的,所以我假定讀者已經知道如何創建一個DLL。通過調用一個Win32 API,下面的代碼實現了固有方法。隨後,它會編譯和鏈接到一個名為MsgImpl.dll的文件里:

#include <windows.h>
#include "ShowMsgBox.h "

BOOL APIENTRY DllMain(HANDLE hMole,
DWORD dwReason, void** lpReserved) {
return TRUE;
}

JNIEXPORT void JNICALL
Java_ShowMsgBox_ShowMessage(JNIEnv * jEnv,
jobject this, jstring jMsg) {
const char * msg;
msg = (*jEnv)-> GetStringUTFChars(jEnv, jMsg,0);
MessageBox(HWND_DESKTOP, msg,
"Thinking in Java: JNI ",
MB_OK | MB_ICONEXCLAMATION);
(*jEnv)-> ReleaseStringUTFChars(jEnv, jMsg,msg);
}

若對Win32沒有興趣,只需跳過MessageBox()調用;最有趣的部分是它周圍的代碼。傳遞到固有方法內部的自變數是返回Java的大門。第一個自變數是類型JNIEnv的,其中包含了回調JVM需要的所有掛鉤(下一節再詳細講述)。由於方法的類型不同,第二個自變數也有自己不同的含義。對於象上例那樣的非static方法(也叫作實例方法),第二個自變數等價於C++的「this」指針,並類似於Java的「this」:都引用了調用固有方法的那個對象。對於static方法,它是對特定Class對象的一個引用,方法就是在那個Class對象里實現的。
剩餘的自變數代表傳遞到固有方法調用里的Java對象。主類型也是以這種形式傳遞的,但它們進行的「按值」傳遞

Ⅶ Java如何調用本地dll庫裡面的方法

JAVA通過JNI調用本地方法,而本地方法是以庫文件的形式存放的(在WINDOWS平台上是DLL文件形式,在UNIX機器上是SO文件形式)。通過調用本地的庫文件的內部方法,使JAVA可以實現和本地機器的緊密聯系,調用系統級的各介面方法。
簡單介紹及應用如下:
一、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++程序調用來生成所需的庫文件

Ⅷ 現在我有一個DLL文件,我想在JAVA中調用DLL文件中的方法,請問如何實現

一般那種c#的dll是java不能直接調用的,但C\C++可以,你可以使用JNI。比如你要一個 public native void sengMsg(String msg); 來發送信息,先用native關鍵字聲明這個函數,然後再類裡面加一個靜態塊: static { System.loadLibrary("msg"); } 這里的msg是你的後來編譯的dll文件名,不是簡訊貓帶的。 然後寫其他的函數就可以調用這個方法了,寫完後用javac編譯,得到class文件,然後用 javah -jni 你的class文件 就會得到一個.h的頭文件,用visual studio新建一個dll,把那個.h文件包含進去,用C\C++調用你現有的dll,然後編譯得到你的msg.dll,把它復制到你的class文件目錄,然後就可以調試運行了。

Ⅸ 怎樣用JAVA調用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 :-)

Ⅹ 請問:Java能編寫DLL嗎

貌似不能(不是不確切,是我的口頭禪)
因為Java編程是跨平台的,它不可能只編寫適用了Windows平台的東西。不過它有相應的東西,這個可以適用於Linux等等平台的!

熱點內容
app什麼情況下找不到伺服器 發布:2025-05-12 15:46:25 瀏覽:714
php跳過if 發布:2025-05-12 15:34:29 瀏覽:467
不定時演算法 發布:2025-05-12 15:30:16 瀏覽:131
c語言延時1ms程序 發布:2025-05-12 15:01:30 瀏覽:165
動物園靈長類動物配置什麼植物 發布:2025-05-12 14:49:59 瀏覽:734
wifi密碼設置什麼好 發布:2025-05-12 14:49:17 瀏覽:148
三位數乘兩位數速演算法 發布:2025-05-12 13:05:48 瀏覽:397
暴風影音緩存在哪裡 發布:2025-05-12 12:42:03 瀏覽:540
access資料庫exe 發布:2025-05-12 12:39:04 瀏覽:628
五開的配置是什麼 發布:2025-05-12 12:36:37 瀏覽:364