Cookie Consent by Privacy Policies website
 
Language selection:   Deutsch   Deutsch   |   English   English

Janino

This programme is presented to you by:

E-mail:aunkrig [at] codehaus [dot] org
Website:docs.codehaus.org/display/JANINO
Category:Development / Other
2.6.1
Win 98 / ME / 2000 / XP / Vista
JDK 1.3.1 or höher
Languages:English
3 in May / 216 in total
 

Rating: 5.00/10 (3 votes cast)

 

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 for Janino

Here you can subscribe for the update infos for this programme. You will then receive an e-mail notice each time an update has been submitted for this programme.

In order to subscribe for the update infos, please enter your e-mail address below. You will then receive an e-mail with a link, which you need to click in order to confirm you subscription.

You can unsubscribe from the list at any time. For this purpose, you will find a link at the end of each update info e-mail.

This service is completely free of charge for you.

Subscribe for update infos
Verification
 

Comments on Janino

There are no comments to this programme.

Write a comment
 

Log in for Authors

Link-Partners

Log in for Link-Partners