decoration decoration
Stories

GROKLAW
When you want to know more...
decoration
For layout only
Home
Archives
Site Map
Search
About Groklaw
Awards
Legal Research
Timelines
ApplevSamsung
ApplevSamsung p.2
ArchiveExplorer
Autozone
Bilski
Cases
Cast: Lawyers
Comes v. MS
Contracts/Documents
Courts
DRM
Gordon v MS
GPL
Grokdoc
HTML How To
IPI v RH
IV v. Google
Legal Docs
Lodsys
MS Litigations
MSvB&N
News Picks
Novell v. MS
Novell-MS Deal
ODF/OOXML
OOXML Appeals
OraclevGoogle
Patents
ProjectMonterey
Psystar
Quote Database
Red Hat v SCO
Salus Book
SCEA v Hotz
SCO Appeals
SCO Bankruptcy
SCO Financials
SCO Overview
SCO v IBM
SCO v Novell
SCO:Soup2Nuts
SCOsource
Sean Daly
Software Patents
Switch to Linux
Transcripts
Unix Books

Gear

Groklaw Gear

Click here to send an email to the editor of this weblog.


You won't find me on Facebook


Donate

Donate Paypal


No Legal Advice

The information on Groklaw is not intended to constitute legal advice. While Mark is a lawyer and he has asked other lawyers and law students to contribute articles, all of these articles are offered to help educate, not to provide specific legal advice. They are not your lawyers.

Here's Groklaw's comments policy.


What's New

STORIES
No new stories

COMMENTS last 48 hrs
No new comments


Sponsors

Hosting:
hosted by ibiblio

On servers donated to ibiblio by AMD.

Webmaster
Not true of Java | 392 comments | Create New Account
Comments belong to whoever posts them. Please notify us of inappropriate comments.
Not true of Java
Authored by: Anonymous on Friday, June 01 2012 @ 08:08 AM EDT
What you say might apply to a scripting language such as Tcl or bash..

Its not true for Java. The way Java works is like this:

(1) programmer writes source code.
(2) programmer (or in rare cases, some complex system) runs Javac to compile the source code into Java bytecode (and related data structures e.g. constant pool) which is placed in .class files.
(3) a Java VM is used to execute the .class files. It might do this with an "interpreter" (which is a bytecode interpreter, not a source-level interpreter as you describe). Or it might use a "JIT compiler" which translates at least some of the bytecode into native machine code, and then executes that native code.

Some VMs use an interpreter to do all of their execution, which is the slowest but simplest and most-portable way to write a VM. Some use JIT compilation to execute everything. And some use a hybrid strategy of using the interpreter for rarely-executed code and JITting the frequently-executed code.

I once worked on a multi-platform Java VM that used a hybrid strategy on some popular x86 platforms, but was also ported to many other platforms where the plain interpreter was used, because porting and maintaining the JIT on those platforms would be a huge amount of work.

(The amount of programming effort it takes to create and maintain a good JIT compiler for Java is similar to the amount of programming effort it takes to make the entire rest of the VM. A bytecode interpreter, by contrast, is much simpler and more portable).

[ Reply to This | Parent | # ]

Groklaw © Copyright 2003-2013 Pamela Jones.
All trademarks and copyrights on this page are owned by their respective owners.
Comments are owned by the individual posters.

PJ's articles are licensed under a Creative Commons License. ( Details )