導航:首頁 > 編程語言 > javadll

javadll

發布時間:2022-01-23 11:49:02

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的幾種方法

一般這種情況建議你去網路下載。直接搜索缺失文件的名稱
下載後直接解壓到缺失的該目錄。
或者打開 開始-運行 -輸入你缺失的文件。
或者你可以用騰訊電腦管家-電腦診所-右上角搜索缺失dll。
根據提示完成修復重啟即可。

㈢ java調用DLL動態庫

1、總體說明:實現一個函數,傳入整形數i,返回值i*i,這個函數做在DLL中,java將通過JNI調用這個函數,傳入一個參數,得到返回值。
確定DLL的名稱為calldll.dll,函數shanfei(int i)。2、編寫java程序javacall.java,如下:public class javacall
{
static
{
System.loadLibrary("calldll");
}
public native static int shanfei(int i);
public static void main(String[] args)
{
javacall jc = new javacall();
int j;
j = jc.shanfei(4);
System.out.println(j);
}
}3、編譯javac javacall.java4、生成頭文件javah -jni javacall
生成javacall.h文件5、製作VC++動態庫建立新DLL工程,程序中添加:#include "javacall.h"
JNIEXPORT jint JNICALL Java_javacall_shanfei (JNIEnv *, jclass, jint p)
{
int j = p*p;
return j;
}別忘了將javacall.h復制到VC工程目錄中,然後編譯,如果編譯說找不到jni.h文件,可以將jni.h復制到工程目錄中,還可將javacall.h文件中的#include <jni.h>改為#include "jni.h",再編譯。
編譯生成DLL文件如「test.dll」,名稱與System.loadLibrary("test")中的名稱一致
vc的編譯辦法:cl -I%java_home%include -I%java_home%includewin32 -LD com_hode_hodeframework_modelupdate_CheckFile.c -Fetest.dll
最後在運行時加參數-Djava.library.path=[dll寄存的路徑]
相關的主題文章: 6、java調用將生成的calldll.dll文件復制到javacall.java所在的目錄中,運行java javacall,應該可以看到運行結果。

㈣ 幾種java調用dll的方式

方法有:
1、用Windows系統盤功能進行文件修復;
2、若在此之前有一鍵備份過,可以重新還原;
3、從網上下載系統文件然後覆蓋到原文件夾里;
4、由於從網上下載系統文件,可能會因為系統文件版本與操作系統不相符造成系統文件不兼容的情況,修復系統文件最好使用專業的工具進行一鍵修復。
5、可以用騰訊電腦管家修復下。打開電腦管家——電腦診所——軟體問題——缺少dll文件。

㈤ java載入dll文件

java沒法直接讀,只能先用C++寫一個讀取該dll內容的過程,按JNI規范封裝成dll,然後java載入這個dll執行其中的函數。

㈥ 「無法啟動此程序,以為計算機中丟失java.dll請重新安裝此程序以解決問題」。

我剛剛也遇到了上述類似問題。我是缺少java_launcher.dll 我是按照網上的方法。不解壓文件,直接提取setup安裝,然後出現了這問題。查看文件發現 /bin/win32/ 文件夾中含有setup.exe 和java——launcher.dll ,從這里安裝試試。 希望可以幫到您

㈦ java卸載不了了,總是說需要的DLL不能運行,請問怎麼辦啊

可以對dll文件恢復。
下載個「系統急救箱」,已經安裝了「安全衛士」,直接打開「查殺木馬」,「自定義掃描」的下面的「系統急救箱」,點擊它:
1、開始急救,急救完畢後,點擊立即處理,重啟。
2、開機後,「文件恢復區」,徹底刪除文件。
3、「系統修復」,全部選擇,點擊立即修復。
4、進行網路修復,點擊開始修復,修復完重啟電腦。
5、dll文件恢復,掃描一下,如果有丟失,添加恢復,沒有就完成了。

㈧ 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如何引用jtwain.dll文件

您好,hi 這個還真沒用過,不過我看過java 類載入機制,
有三個載入方式:
根載入器(頂級):Bootstrap Loader
擴展類載入器:Extended Loader
系統類載入器:AppClass Loader
其中頂級載入器 並不是調用java載入的,而是調用C dll載入的,你可以看一下這一塊的java源碼
package org.scavino.twain;

import ins.filemanager.fileuploader.FileUploaderConst;
import ins.filemanager.fileuploader.FileUploaderFrame;
import ins.filemanager.fileuploader.FileUploaderParams;

import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;
import java.util.StringTokenizer;

import javax.swing.JOptionPane;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

public class JTwain {
private static final Log logger = LogFactory
.getLog(JTwain.class);

private static final JTwain mInstance = new JTwain();

protected final String DLL_NAME = "jtwain";

private JTwain() {
initLib();
}

public static JTwain getInstance(){
return mInstance;
}

public native boolean isTwainAvailble();

public native String[] getAvailableSources();

public native String[] acquire();

public native String[] acquire(String sourceName);

/*
* Loads the C/JNI Libray
*/
private void initLib(){

try {
String libraryPath = System.getProperty("java.library.path");

if ((libraryPath == null) || (libraryPath.trim().length() == 0)) {
logger.info("");
return;
}

String systemDir = null;
String firstEntry = null;
String original;
String entry;

StringTokenizer st = new StringTokenizer(libraryPath, ";");
int i = 0;
while (i < st.countTokens()) {
original = st.nextToken();
entry = original;
if (i == 0) {
firstEntry = entry;
}
if (entry.endsWith("\\")) {
entry = entry.substring(0, entry.length() - 1);
}
entry = entry.toLowerCase();
if (entry.endsWith("windows\\system")) {
systemDir = original;
break;
}
if (entry.endsWith("winnt\\system32")) {
systemDir = original;
break;
}
if (entry.endsWith("windows\\system32")) {
systemDir = original;
File file = new File(original.replace("System32", "SysWow64"));
if(file.exists()){
systemDir = file.getPath();
}
break;
}

i++;
}
if (systemDir == null) {
systemDir = firstEntry;
}
installFile(new URL(FileUploaderConst.FileUploadURL), systemDir
+ "/jtwain.dll");

System.loadLibrary(DLL_NAME);
} catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
logger.error(e);
}

finally {
// Send to your logging subsystem
System.out.println("Loading : " + DLL_NAME + ".dll");
}
}

/**
* dll
*/
protected static void installFile(URL sourceUrl, String destFileName) {
File destFile = new File(destFileName);
if (!destFile.exists()) {
try {
System.err.println("installing file " + destFileName);
destFile.getParentFile().mkdirs();
URLConnection connection = sourceUrl.openConnection();
InputStream is = connection.getInputStream();
FileOutputStream fos = new FileOutputStream(destFile);
byte[] buff = new byte[8192];
BufferedInputStream in = new BufferedInputStream(is,
buff.length);
BufferedOutputStream out = new BufferedOutputStream(fos,
buff.length);
int i;
int count = 0;
while ((i = in.read(buff, 0, buff.length)) != -1) {
out.write(buff, 0, i);
count += i;
}
in.close();
out.close();
} catch (Exception exception) {
exception.printStackTrace();
logger.error(exception);
}
}
}

}

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

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

閱讀全文

與javadll相關的資料

熱點內容
動態庫在程序編譯時會被連接到 瀏覽:759
python超簡單編程 瀏覽:257
獲取命令方 瀏覽:976
怎樣製作文件夾和圖片 瀏覽:58
調研編譯寫信息 瀏覽:860
python馮諾依曼 瀏覽:417
同時安裝多個app有什麼影響 瀏覽:254
奧術殺戮命令宏 瀏覽:183
用sdes加密明文字母e 瀏覽:360
單片機原理及應用試題 瀏覽:424
易語言開啟指定文件夾 瀏覽:40
馬思純參加密室大逃脫 瀏覽:322
文件夾冬季澆築溫度 瀏覽:712
京東有返點的aPp叫什麼 瀏覽:603
如何查看u點家庭伺服器是幾兆 瀏覽:262
python應用介面怎麼接 瀏覽:67
腐蝕怎麼進不去伺服器啊 瀏覽:359
linuxcpiogz 瀏覽:631
安卓中的布局是什麼文件 瀏覽:397
dex反編譯部分代碼無法查看 瀏覽:464