Janino 2.5.12 |
| Size: | 104 kB | Company: | Arno Unkrig | |
| License: | freeware | Date added: | 03/05/2005 | |
| Platform: | Win95,Win98,WinME,WinNT 3.x,WinNT 4.x,Windows2000,WinXP,Unix,Linux,Mac PPC | Number of downloads: | 0 | |
| Download: | free download | Average user rating: | This program has not yet been rated, you can be the first. | |
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,
What is new:
Updated the overview page.
Related programs: | |||
| Arcade Park The Matrix Edition 7 Arcade Park is a remix collection of the great golden oldies games. | eBook Pack Express 1.75 Compile HTML and graphic files into e-books. | ||
| Quick Batch File Compiler 2.0.7.0 Quick Batch File compiler convert batch files into actual program in one click | BMDFM 5.9.9 revi Binary Modular DataFlow Machine - Parallel Programming Environment | ||
| Quick Number Base Converter 1.3 System tray tool to convert number bases: hex, decimal, binary, ascii, etc | Vistascript Developer 1.0 Vistascript is a scripting development environment and runtime for WinFx | ||