RFR (L) 8037210: Get rid of char-based descriptions 'J' of basic types (original) (raw)

Christian Thalinger christian.thalinger at oracle.com
Wed Mar 19 01šŸ”ž06 UTC 2014


On Mar 18, 2014, at 2:35 PM, John Rose <john.r.rose at oracle.com> wrote:

On Mar 18, 2014, at 1:36 PM, Christian Thalinger <christian.thalinger at oracle.com> wrote:

Why are we not using an Enum instead of an "untyped" byte? Byte is moderately typed, in the sense (which I rely on during development) that you can't assign an int or char to a byte w/o a cast. That's why it is not just a plain int. But those values (LTYPE etc.) are used a lot as numbers, and specifically as low-level array indexes, and also comparisons (x < VTYPE). To turn them into enums, we'd have to add lots of calls to '.ordinal()' to turn them right back to numbers. That dilutes (completely IMO) the value they have as enums to raise the level of the code.

But without being strongly typed we get bugs like this one: @Override

I’m just saying that for the sake of maintainability and correctness an Enum would be better.

— John


mlvm-dev mailing list mlvm-dev at openjdk.java.net http://mail.openjdk.java.net/mailman/listinfo/mlvm-dev



More information about the core-libs-dev mailing list