在.net应用中调用java程序
本例主要是介绍利用C#程序调用已经写好的JA V A程序.
很多时候我们不可避免的要用到别人写的东西.就拿我来说.很多应用是用.NET写的.也有很多程序是用JA V A写的.这就带来了很多麻烦,有时候要实现同样的功能,必须写两遍代码.
那么我们有没有办法让C#直接调用java写好的东西呢?(java直接调用.net的程序也是可以的).
这里需要提到的就是http://www.doczj.com/doc/c577901b52ea551810a6877a.html开源程序.这个开源程序不想过多的介绍.说多了也没有太多的意义,有兴趣的朋友可以深入研究.他的源代码可以到http://www.doczj.com/doc/c577901b52ea551810a6877a.html/project/showfiles.php?group_id=69637去下载.
简单的介绍一下http://www.doczj.com/doc/c577901b52ea551810a6877a.html 还是有必要的.
http://www.doczj.com/doc/c577901b52ea551810a6877a.html是一个针对Mono和微软.net框架的java实现,其设计目的是在.NET平台上运行java程序。它包含了以下的组建:
* 一个用.NET实现的java虚拟机
* 一个java类库的.NET实现
* 致力于在java和.NET之间交互的工具
还要说一下我们将要用到的http://www.doczj.com/doc/c577901b52ea551810a6877a.html中我们将要用到的部分.
* IKVM.Runtime.dll: VM运行时和所有支持代码。它包括以下的功能:
Byte Code JIT 编译器和验证器: 使用JIT将Java Byte Code编译为CIL(C中间语言)。
对象模式映射结构: 将.NET中的System.Object,System.String,System.Exception映射为java代码中的http://www.doczj.com/doc/c577901b52ea551810a6877a.htmlng.Object,http://www.doczj.com/doc/c577901b52ea551810a6877a.htmlng.String,http://www.doczj.com/doc/c577901b52ea551810a6877a.htmlng.Throwable。
管理本地方法(在Classpath中)的.NET重新实现。
* IKVM.GNU.Classpath.dll: 被编译的GNU Classpath版本,它是由自由软件基金会实现的java类库和一些http://www.doczj.com/doc/c577901b52ea551810a6877a.html附加代码组成的。注意:这里的GNU Classpath不是http://www.doczj.com/doc/c577901b52ea551810a6877a.html的一部分,但是前者被用在http://www.doczj.com/doc/c577901b52ea551810a6877a.html中。
* IKVM.JNI.[Mono|CLR-Win32].dll: 通过实现JNI接口管理C++汇编。作为一个可选部分,只在程序使用自己的本地库时才被用到。而对于纯java程序来讲是不会被用到的。
* ikvm.exe: 与java.exe很类似的启动执行程序(动态模式)。
* ikvmc.exe: 静态编译器,被用来编译java类和jar使其成为.NET汇编(静态模式)。
* ikvmstub.exe: 一个从.NET汇编生成存根类的工具,就如javap一样反编译.NET汇编。http://www.doczj.com/doc/c577901b52ea551810a6877a.html了解如何存根并用实际的.NET类型引用替换对存根的引用。
* IKVM.AWT.WinForms.dll: 非常有限的零散AWT实现。
安装IKVM直接把文件解压到某目录就可以了.
下面就看我们的示例:
// ***********************************************************************
//
// .NET中使用JA V A的例子
//
// Copyright ? 2007 http://www.doczj.com/doc/c577901b52ea551810a6877a.html
// All Rights Reserved
// This library is free software; you can redistribute it and/or
// modify it under the terms of the Apache Software License as
// published by the Apache Software Foundation; either version 1.1
// of the License, or (at your option) any later version.
//