I've looked a little more at javap and it lies about the major and minor
versions. You need to look in the .class file itself with a hex editor and
look at the second word. However, based on your stack trace, try running
with the option -verbose:class. This should show you classloader activity
so you can see where your class is getting loaded from.

HTH,
Gary

-----Original Message-----
From: java400-l-bounces@xxxxxxxxxxxx
[mailto:java400-l-bounces@xxxxxxxxxxxx]
On Behalf Of Mark Walter
Sent: Monday, March 30, 2009 10:09 AM
To: Java Programming on and around the iSeries / AS400
Subject: RE: Java Version issues

See inline..

Thanks,

Mark
-----Original Message-----
From: java400-l-bounces@xxxxxxxxxxxx
[mailto:java400-l-bounces@xxxxxxxxxxxx]
On Behalf Of Thorbjoern Ravn Andersen
Sent: Monday, March 30, 2009 11:30 AM
To: Java Programming on and around the iSeries / AS400
Subject: Re: Java Version issues

Mark Walter skrev:
I'm trying to run a java class on my 400. But I'm getting an
UnsupportedClassVersionError. I compiled the class in Netbeans with
version
1.4.2. Which is what java -version shows in QSH on the iSeries.

If I try to do a JAVAP -Verbose on the class, it returns major and minor
versions of both 0. Is there any way to debug this error further?

Some ideas:

Run javap on your pc against the java class file
Still returns major 0 minor 0

Double check that the file was transferred in binary mode if using ftp.
Dropped into iNav from my PC/

Ensure you don't have a JAVA_HOME variable set.
Not sure where to set this, but there is no environment variable as such.

Force the java version with "java -Djava.version=1.4 MyClass"
Same error.

Use "java -verbose MyClass" to see when the class breaks.
Here is where it fails:
Loading class java.lang.ThreadLocal$ThreadLocalMap$Entry from
/QIBM/ProdData/
OS400/Java400/jdk/lib/rt.jar
at java.lang.Throwable.<init>(Throwable.java:195)
at java.lang.Error.<init>(Error.java:49)
at
java.lang.UnsupportedClassVersionError.<init>(UnsupportedClassVers
ionError.java:34)
at java.lang.ClassLoader.defineClass(ClassLoader.java:567)
at
java.security.SecureClassLoader.defineClass(SecureClassLoader.java
:168)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:312)
at java.net.URLClassLoader.access$300(URLClassLoader.java:85)
at
java.net.URLClassLoader$ClassFinder.run(URLClassLoader.java:636)



--
Thorbjørn Ravn Andersen "...plus... Tubular Bells!"


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.