「dll生成java」dll生成lib 和h

博主:adminadmin 2023-03-21 05:32:06 490

本篇文章给大家谈谈dll生成java,以及dll生成lib 和h对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

请问怎么把.dll文件加入我的java工程,并能使用里面的方法?

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文件:

1msdev-new-project-win32 Dynamic-Link Library

2Enter project name (e.g. VCdll)

3choose "An empty DLL project"-finish

4将3生成的TestNative.h和jdk下的jni.h和jni_md.h加入到工程中去

5Create 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中的反射机制做到,但是java中是没有动态链接库这种东西的。如果你指的是java调用本地dll的话,是使用jni技术,dll也不是java编写的。总是java是不可能编译成为dll。有一种这种的方案,就是将java编译的文件转换为c#的,微软有相应的工具,可以搜到,然后就可以打包成为dll了。

jar生成dll自动编译依赖

研究很好几天,终于成功了。因为写了一个Java的项目,现在要求要改写成C#版本的。但是其中用到了svnkit,svnkit是java平台的。改写成C#的话,要使用SharpSVN,但是SharpSVN的API文档真的很不专业。看来看去还是svnkit比较好。所以打算将一些操作(上传,下载,删除,移动,检索树)写好之后,转成dll。于是开始了研究。

首先遇到的问题是:jar包之间有依赖的话,转成dll。在运行过程中会出现找不到类的错误。最终找到了解决办法:有两种办法。

1.使用fatjar将他们统一一键打包(依赖包可以存在新建的lib文件夹中),再使用

ikvmc -target:library 打包好的fatjar文件路径

来将jar包转成dll。

在新建的C#工程中添加引用(添加转好的dll),直接使用打包好的函数就行。(就像使用库函数)

2.第二种方法是这样的:

我举个例子说明一下:一个类名为:GetUserName(),将其导出为jar(BeDependent.jar)。再写一个类命名为InvokeGetUserName(),并且在InvokeGetUserName()中调用了GetUserName()。将InvokeGetUserName打包成另一个jar(ToDependent.jar)。

接下来:先将没有依赖的jar包转成dll,这里指的就是BeDependent.jar。

ikvmc -target:library BeDependent.jar的路径

会生成BeDependent.dll,然后将两个jar包合成:

ikvmc -target:library -reference:BeDependent.dll的路径 ToDependent.jar的路径

生成ToDependent.dll。在新建的C#项目中加载引用后,直接在程序中直接调用InvokeGetUserName()即可。

注:但是在我合成svnkit的jar们的时候,出现了问题。还没有解决。

Jar包转成Dll的方式(带嵌套的jar也能做)的更多相关文章

Jar包转成Dll的方式(带嵌套的jar也能做) (转)

研究很好几天,终于成功了.因为写了一个Java的项目,现在要求要改写成C#版本的.但是其中用到了svnkit,sv

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?

JAVA以其跨平台的特性深受人们喜爱,而又正由于它的跨平台的目的,使得它和本地机器的各种内部联系变得很少,约束了它的功能。解决JAVA对本地操作的一种方法就是JNI。

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++程序调用来生成所需的库文件。

二、C/C++中所需要做的工作

对于已生成的.h头文件,C/C++所需要做的,就是把它的各个方法具体的实现。然后编译连接成库文件即可。再把库文件拷贝到JAVA程序的路径下面,就可以用JAVA调用C/C++所实现的功能了。

接上例子。我们先看一下testdll.h文件的内容:

#i nclude jni.h

#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文件具体实现这两个函数:

#i nclude "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运行它,就可以观察到结果了。

dll生成java的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于dll生成lib 和h、dll生成java的信息别忘了在本站进行查找喔。