Java-Gaming.org    
Featured games (81)
games approved by the League of Dukes
Games in Showcase (482)
Games in Android Showcase (110)
games submitted by our members
Games in WIP (548)
games currently in development
News: Read the Java Gaming Resources, or peek at the official Java tutorials
 
    Home     Help   Search   Login   Register   
Pages: [1]
  ignore  |  Print  
  Annotations and Java's hotspot compiler  (Read 1478 times)
0 Members and 1 Guest are viewing this topic.
Offline K.I.L.E.R

Senior Member




Java games rock!


« Posted 2005-04-07 09:52:29 »

Annotations can be used to speed up java.

A lot of people may try to murder me for this suggestion, but I believe Princec mentioned this in another thread but it never took off, conversation wise anyway.

The ability to manipulate the hotspot compiler using annotations in the code.

What this could mean?
Removal of bounds checking on arrays in loops, in collections, in methods and classes.

IE: "Object[] a = new Object[4096]; @bounds_removal"

or
1  
2  
3  
4  
5  
6  
7  
8  
9  
Object[] stuff = new Object[4096];
....
@remove_bounds
public Object findObject(long id, String name, etc ...)
{
    Object hnd = null;
    ....
    return hnd;
}


At this moment it's the only thing I can come up with.
However the power of annotations could be expanded, the beauty of this is that newcomers to Java don't need to know this stuff, nor will they be taught this stuff at low levels.

The benefits would outweigh the pains.
After you've finished your game or application you would profile it.
You would visit the hotspots and do standard code optimisations on it, however even after you have visited every hotspot you may decide that there are areas where further improvements would be extremely beneficial as a whole.
In those areas are where developers will gain the advantage of using annotations to create hints for the hotspot compiler.

What do you guys think? Is this a great idea or am I just a paranoid delusional power user?

Vorax:
Is there a name for a "redneck" programmer?

Jeff:
Unemployed. Wink
Offline erikd

JGO Ninja


Medals: 16
Projects: 4
Exp: 14 years


Maximumisness


« Reply #1 - Posted 2005-04-07 20:29:16 »

In your example you use code to give a hint to the VM that it should become unsafe in order to get some performance boost. This is just not possible for java. The VM should always decide when and where it's safe to remove bounds checks, not the programmer, or else you throw one of java's most important features out of the window which is safety.
This will never happen. If you don't want bounds checks, use a native compiler (you can disable bounds checking in GCJ), or use C/C++.
Personally, I don't think using an aot compiler is worth it just for the tiny performance boost you might get from disabled bounds checks.

Offline erikd

JGO Ninja


Medals: 16
Projects: 4
Exp: 14 years


Maximumisness


« Reply #2 - Posted 2005-04-07 20:43:21 »

Second thought  Smiley
Maybe such a hint should not cause the VM to blindly disable bounds checks, but immediately at load time start investigating the code to see if it's safe to do so. This could maybe improve warm-up behaviour  somewhat (not run-time performance), although I have no idea how much, or if it'll even be worthwhile. But worth some more thought maybe.

Games published by our own members! Check 'em out!
Legends of Yore - The Casual Retro Roguelike
Offline princec

JGO Kernel


Medals: 362
Projects: 3
Exp: 16 years


Eh? Who? What? ... Me?


« Reply #3 - Posted 2005-04-07 22:38:00 »

I reckon annotations would be a great way of introducing mapped objects ("structs").

Cas Smiley

Pages: [1]
  ignore  |  Print  
 
 
You cannot reply to this message, because it is very, very old.

 

Add your game by posting it in the WIP section,
or publish it in Showcase.

The first screenshot will be displayed as a thumbnail.

CopyableCougar4 (9 views)
2014-08-22 19:31:30

atombrot (28 views)
2014-08-19 09:29:53

Tekkerue (25 views)
2014-08-16 06:45:27

Tekkerue (23 views)
2014-08-16 06:22:17

Tekkerue (15 views)
2014-08-16 06:20:21

Tekkerue (22 views)
2014-08-16 06:12:11

Rayexar (61 views)
2014-08-11 02:49:23

BurntPizza (39 views)
2014-08-09 21:09:32

BurntPizza (31 views)
2014-08-08 02:01:56

Norakomi (37 views)
2014-08-06 19:49:38
List of Learning Resources
by Longor1996
2014-08-16 10:40:00

List of Learning Resources
by SilverTiger
2014-08-05 19:33:27

Resources for WIP games
by CogWheelz
2014-08-01 16:20:17

Resources for WIP games
by CogWheelz
2014-08-01 16:19:50

List of Learning Resources
by SilverTiger
2014-07-31 16:29:50

List of Learning Resources
by SilverTiger
2014-07-31 16:26:06

List of Learning Resources
by SilverTiger
2014-07-31 11:54:12

HotSpot Options
by dleskov
2014-07-08 01:59:08
java-gaming.org is not responsible for the content posted by its members, including references to external websites, and other references that may or may not have a relation with our primarily gaming and game production oriented community. inquiries and complaints can be sent via email to the info‑account of the company managing the website of java‑gaming.org
Powered by MySQL Powered by PHP Powered by SMF 1.1.18 | SMF © 2013, Simple Machines | Managed by Enhanced Four Valid XHTML 1.0! Valid CSS!