Cookie Consent by Privacy Policies website
 
Sprachauswahl:   Deutsch   Deutsch   |   English   English

Login für Autoren

Link-Partner

Login für Link-Partner

Janino

Dieses Programm wird Ihnen präsentiert von:

E-Mail aunkrig [at] codehaus [dot] org
Website docs.codehaus.org/display/JANINO
Entwicklung / Sonstige
2.6.1
Win 98 / ME / 2000 / XP / Vista
JDK 1.3.1 or höher
Englisch
0 im Juli / 220 insgesamt
 

Bewertung: 5,00/10 (3 Stimmen abgegeben)

 

Janino is a compiler that reads a Java expression, block, or source file, and generates Java bytecode that is loaded and executed directly. It is not intended to be a development tool, but an embedded compiler for run-time compilation purposes, such as expression evaluators or "server pages" engines like JSP.

Properties

The major design goal was to keep the compiler small and simple, while partially sacrificing completeness. I don't like the idea of carrying around huge libraries for simple applications. See Parser for the list of implemented and missing language features.

When do you need an efficient expression evaluator?

Say you build an e-commerce system, which computes the shipping cost for the items that the user put into his/her shopping cart. Because you don't know the merchant's shipping cost model at implementation time, you could implement a set of shipping cost models that come to mind (flat charge, by weight, by number of items, ...) and select one of those at run-time.

In practice, you will most certainly find that the shipping cost models you implemented will rarely match what the merchant wants, so you must add custom models, which are merchant-specific. If the merchant's model changes later, you must change your code, re-compile and re-distribute your software.

Because this is so unflexible, the shipping cost expression should be specified at run-time, not at compile-time. This implies that the expression must be scanned, parsed and evaluated at run-time, which is why you need an expression evaluator.

A simple expression evaluator would parse an expression and create a "syntax tree". The expression "a + b * c", for example, would compile into a "Sum" object who's first operand is parameter "a" and who's second operand is a "Product" object who's operands are parameters "b" and "c". Such a syntax tree can evaluated relatively quickly. However, the run-time performance is about a factor of 100 worse than that of native Java code.

 

Update-Infos für Janino

Einblenden / Ausblenden

Hier können Sie die Update-Infos für dieses Programm abonnieren. Sie erhalten dann zukünftig eine Benachrichtigung per Email, sobald ein Update zu diesem Programm eingetragen wurde.

Um die Update-Infos zu abonnieren, tragen Sie nachfolgend Ihre E-Mail-Adresse ein. Sie erhalten dann eine E-Mail mit einem Link, über den Sie das Abo bestätigen müssen.

Sie können die Update-Infos jederzeit wieder abbestellen. Hierzu finden Sie am Ende jeder E-Mail mit Update-Infos einen entsprechenden Link.

Dieser Service ist für Sie vollkommen kostenlos.

Update-Infos abonnieren
Verifizierung
 

Kommentare zu Janino

Einblenden / Ausblenden

Bisher gibt es keine Kommentare zu diesem Programm.

Selbst einen Kommentar schreiben