I recently learned that there are Class representations for the primitive types in the JVM. For example, int.class, double.class, and even a void.class.
What I don’t understand is why these are there. They don’t seem to serve any functional role. Using reflection, I searched through the classes, and they have no constructors, no methods, and no fields. For all intents and purposes, they seem empty and useless. The primitive type variables are not even instances of their respective classes, as indicated by the following returning false:
int a = 3;
int.class.isInstance(a);
So why do they exist? They must serve some purpose, maybe for the compiler or something, but whatever it is is completely beyond me. There is even an explicit reference to int.class in the Integer API (and likewise for each primitive type and its respective wrapper Object). I haven’t been able to find any reference to their existence, much less their use, in the JLS.
Consider the following:
Without a
Classrepresentation ofint, what would the above return? It shouldn’t returnInteger.classas they’re not the same thing. (Imagine trying to distinguish between methods which were overloaded, one with anintand one with anIntegerparameter.)I’ve used these classes before to provide default values for arguments when calling them via reflection. Based on the parameter type, I’ve used
nullfor any reference type, and some (boxed, obviously) primitive value for each of the primitive types.