Jython 调用 Java 碰壁全纪录

JavaClass 的定义
public class JavaClass {
    private String str = "";
    public JavaClass() {
        this.str = "JavaClass Init";
    }
    public String getStr() {
        return str;
    }
    public void setStr(String str) {
        this.str = str;
    }
}

 

一、命令行模式

 

1、进入 jython 目录,查看当前目录下只有一个JavaClass.java文件

D:\>cd jython
D:\jython>dir
2012-03-13  09:59    <DIR>          .
2012-03-13  09:59    <DIR>          ..
2012-03-13  09:59               227 JavaClass.java
               1 个文件            227 字节
               2 个目录 37,943,169,024 可用字节
               
2、启动Jython 命令行模式(jython版本是 2.2.1)

D:\jython>jython

 

3、导入 JavaClass时,提示找不到JavaClass模块

>>> import JavaClass
Traceback (innermost last):
    File "<console>", line 1, in ?
ImportError: no module named JavaClass

原因:Jython中导入的是.class文件,而JavaClass.java尚未编译生成 .class文件

 

4、Ctrl-Z退出 Jython, 编译 JavaClass.java

D:\jython>javac JavaClass.java
D:\jython>dir
2012-03-13  10:12    <DIR>          .
2012-03-13  10:12    <DIR>          ..
2012-03-13  10:12               443 JavaClass.class
2012-03-13  09:59               227 JavaClass.java
               2 个文件            670 字节
               2 个目录 37,943,169,024 可用字节

 

5、按第2步,再次进入Jython模式后导入 JavaClass时未报异常,说明成功导入,简单调用情况如下

D:\jython>jython
>>> import JavaClass
>>> jc = JavaClass()
>>> jc.str    // 调用get方法
'JavaClass Init'
>>> jc.str = "JavaClass CMD"    // 调用set方法
>>> jc.str

'JavaClass CMD'

 

二、eclipse IDE 环境

workplace 是d:\python,项目名称是mython,其结构如下

mython
    ......
    bin
        javaDemo
            JavaClass.class
        jythonDemo
            Jy2Ja.py
    lib
        ......
        jython.jar
    src
        javaDemo
            JavaClass.java
        jythonDemo
            Jy2Ja.py

 

1、JavaClass.java同上(但是第一行多了一个package javaDemo的定义)

 

2、编辑Jy2Ja.py如下:

from javaDemo import JavaClass
jc = JavaClass()
print jc.str
jc.str = "JavaClass IDE"
print jc.str

测试运行时报异常
Traceback (most recent call last):
  File "D:\python\Mython\src\jythonDemo\Jy2Ja.py", line 4, in <module>
    from javaDemo import JavaClass
ImportError: No module named javaDemo

原因:找不到javaDemo是因为“当前路径”下找不到JavaDemo文件或者目录

解决方法:可以在导入JavaClass之前导入sys.path,再 print sys.path 查看“当前路径”如下:
['D:\\python\\Mython\\src\\jythonDemo', 'C:\\Java\\jdk1.6.0_21\\jre\\lib\\resources.jar', 'C:\\Java\\jdk1.6.0_21\\jre\\lib\\rt.jar', ......, '__classpath__', '__pyclasspath__/']

手工添加 'D:\python\Mython\src\JavaDemo'到sys.path里,但是必须在导入JavaClass之前(Python是脚本语言,行解释的)

 

3、Jy2Ja.py修改后如下:

import sys.path  as path
path.append("D:\python\Mython\src\javaDemo")
from javaDemo import JavaClass
jc = JavaClass()
print jc.str
jc.str = "JavaClass IDE"
print jc.str

测试运行时仍然报2中的异常,找不到JavaDemo

原因:手工添加的 'D:\python\Mython\src\JavaDemo'有问题。因为在eclipse IDE中,每个类都在一个包里,而包是当前路径的一部分,即JavaClass已经在包JavaDemo中

 

4、再次修改后如下:

import sys.path  as path
path.append("D:\python\Mython\src")
from javaDemo import JavaClass
jc = JavaClass()
print jc.str
jc.str = "JavaClass IDE"
print jc.str

测试运行时仍然报异常
Traceback (most recent call last):
  File "D:\python\Mython\src\jythonDemo\Jy2Ja.py", line 4, in <module>
    from javaDemo import JavaClass
ImportError: cannot import name JavaClass
但是与2中的异常不一样:不能导入JavaClass。

原因:不能导入说明找到了,但是导入的时候出了问题。

        在命令行中第3步中提到Jython文件导入的应该是.class文件,在看前面mython项目的整个目录发现,class文件在mython\bin\javaDemo中。也就是说可能是因为编译器找到了JavaClass的定义即 JavaClass.java,但是找不到它的.class文件。

那java文件对应的class文件为什么不是在src包下的JavaDemo中,而是在bin包下的JavaDemo中?

        右击项目mython->Properties->Java Build Path->source最下面有default output folder中默认的是mython\bin,且这个目录在 Package Explorer视图下是看不到的,在Navigator视图中可以看到。

 

5、将default output folder 修改为 mython\src,目录结构变化如下

mython
    ......
    lib
        ......
        jython.jar
    src
        javaDemo
            JavaClass.class
            JavaClass.java
        jythonDemo
            Jy2Ja.py

 

测试运行成功:
JavaClass Init
JavaClass IDE
 

 

总结:对于新手不太习惯命令行式的Java程序调试,IDE虽然简单方便,但是都有自己默认的规则。这些规则新手可能注意不到,所以在IDE环境中照搬程序源码的时候,总会报一些奇奇怪怪的错误,使得本来简单的问题看上去很复杂。究其原因:1、对开发环境不熟悉、2、java基础不扎实。

 

特殊情况备注:

        1、***.py文件运行时,默认路径即该文件的所在路径,导入***.class时的路径就变成了 ***.py所在的包 + from中的包,即默认.class文件是在 ***.py所在的包 的 子包中,所以在调用Java文件时,需要特别添加class文件所在路径。即使Java文件和Jython文件在同一个包中,Java文件仍然在某个包中,测试运行时仍然要设置java文件所在的包最上级所在的目录,一般为 src。

        2、将Java文件和Jython文件都放在 src 下时,虽然目录结构中显示一个叫"(default package)",但是在Java文件的内部是没有包的设定的,这种情况下运行Jython文件时,可不手工设置class文件所在路径,因为此时 Jython文件的所在目录为src,而Java文件也在src中,且没有包名引起的问题。

        3、其实只要Jython文件在 src 下,Java文件在哪里都可以

 

刚刚接触 Python,正在学习java开发,故从 Jython 入手。因为基础不太扎实,期间诸多碰壁,仅此记录。

成长的道路上不怕跌倒,怕的是的跌倒了再也爬不起来。为自己加油!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值