| |
只编写一套 java 代码即可使它在安装了 java 运行时环境的每个系统上运行,这是 java 的主要优点之一。但这种平台独立性有一大缺点:如何利用大量的现有代码呢?解决这一问题的技巧即使用所谓的 本地方法接口。 编写本地方法需要将 c 代码导入 java 应用程序中。在这篇技巧中,我将逐步分析创建本地方法以及在 java 应用程序中使用这些本地方法的基本步骤。 步入本地方法圣殿的七个步骤 创建本地方法的步骤如下所示: 编写 java 代码 编译 java 代码 创建 c 头文件(.h 文件) 创建 c stubs 文件 编写 c 代码 创建共享代码库(或 dll) 运行应用程序 我们的任务是在本地方法内向控制台输出一些文本。本例的细节将特定于一种类 unix 的系统,明确地说,就是 linux。我还会指出在细节上与其他平台不同的地方。 编写 java 代码 像往常一样编写 java 代码。要在 java 代码中使用本地方法,必须完成两项任务。首先,为您要使用的每个本地方法编写本地方法声明。这与编写普通 java 方法接口的声明没什么不同,但您必须指定 native 关键字,如下所示: public native void printtext (); 必经的第二个环节是您必须显式地加载本地代码库(我们稍后会创建它)。为此,我们在类的一个静态块中加载这个库: static { system.loadlibrary ("happy"); } 为了将这些代码整合在一起,请创建一个名为 happy.java 的文件,其内容如下所示: class happy { public native void printtext (); static { system.loadlibrary ("happy"); /* 请注意,类名是小写的! */ } public static void main(string[] args) { happy happy = new happy (); happy.printtext (); } } 编译 java 代码 编译 happy.java 文件: % javac happy.java 创建 c 头文件 为了将我们的 c 代码用作本地方法,您必须使用一些极好的固定做法。java 编译器的 javah 功能将根据 happy 类生成必要的声明。这将生成 happy.h 文件,以供在我们的 c 代码中包括它: % javah happy 创建 c stubs 文件 回忆一下 c++ 转换程序对 c++ 方法名的处理,java 编译器也有类似的愚蠢行为。为了减轻不得不编写大量乏味代码(以便在 java 运行时系统中调用 c 代码)的痛苦,java 编译器可为我们自动生成必要的框架代码 (trampoline code): % javah -stubs happy 编写 c 代码 现在,我们编写用来显示问候语的实际代码。根据约定,我们将这段代码存入一个文件中,该文件的名称为我们的 java 类名加上字符串 "imp"。其结果就是 happyimp.c。请将以下代码存入 happyimp.c: #include /* 标准本地方法信息。*/ #include "happy.h" /* 前面生成的头文件。*/ #include /* 标准 c io 信息。*/ void happy_printtext (struct hhappy *this) { puts ("happy new year!!!"); } 将 c 代码与 java 对接还涉及许多其他方面 -- 如如何传递和返回 myriad 类型。 有关详细信息,请参阅 java tutorial 或 hermetica 的本地方法论文(有关 url,请参阅参考资源部分)。 创建共享库 本部分是与系统最紧密相关的部分。似乎每种平台和每种编译器/链接器的组合都用不同的方法来创建和使用共享库。如果您使用的是 microsoft windows 平台,要了解详细信息,请查看您所用的 c 编译器的文档。 如果您是 linux 用户,请阅读以下使用 gcc 创建共享库的步骤。首先,编译我们所创建的 c 源文件。您必须通知编译器在何处查找此 java 本地方法的支持文件,但此处的主要技巧是您必须显式通知编译器生成位置无关的代码: % gcc -i/usr/local/java/include -i/usr/local/java/include/genunix -fpic -c happy.c happyimp.c 现在,请用下面极好的固定做法根据所生成的对象 (.o) 文件创建共享库: % gcc -shared -wl,-soname,libhappy.so.1 -o libhappy.so.1.0 happy.o happyimp.o 请将共享库文件复制为标准短名: % cp libhappy.so.1.0 libhappy.so 最后,您可能需要通知动态链接程序在何处查找这个新的共享库文件。使用 bash shell: % export ld_library_path=`pwd`:$ld_library_path 执行应用程序 像往常一样运行此 java 应用程序: % java happy 好了,这就是所要做的全部工作。感谢 tony dering 提供了 linux 特定的固定做法。 设计点滴 在埋头为全部遗留代码编写本地方法之前,我提醒您一定要仔细审查系统,看是否可用更好的方法将它们结合到 java 中。例如,在 java 中,您可以用 java 数据库连接 (jdbc) 甚至更高级的解决方案来访问数据库。因此,请查看您掌握的全部技巧,并使用就您手头的项目而言比较合理的解决方案。
|
|