I have a constructor (for an auto generated class) that has 255 paremeters. Using ant on linux with javac 1.6.0_02. The class compiles fine and everything is good.
However when I try to compile the same class from within eclipse on windows xp with jdk 1.6, I get the following error
Too many parameters, parameter BLAH is exceeding the limit of 255 words eligible for method parameters
BLAH is the the 256th parameter.
Is there a way to overcome this problem? Changing the auto generated class is not an option as I would need to change it every compile or change the generator. Both options are not acceptable because we can already get this class on linux.
PS: For those who are interested, the java class is generated from an IDL file using JacORB. Unfortunately the number of parameters in the class can not be reduced as it defines an interfaces between our software and other systems.
解决方案
The number of method parameters is
limited to 255 by the definition of a
method descriptor (§4.3.3), where the
limit includes one unit for this in
the case of instance or interface
method invocations. Note that a method
descriptor is defined in terms of a
notion of method parameter length in
which a parameter of type long or
double contributes two units to the
length, so parameters of these types
further reduce the limit.
I suggest you overcome the obstacles in changing the generated code... I'm pretty surprised it works on Linux, to be honest. I wouldn't be entirely surprised if the bytecode it generated was strictly invalid, and it just happens to be working for you at the moment.
While it's always tempting to try to find ways of keeping with the existing code and ignoring the limits, I think in this case you should turn your attention to reducing the number of parameters immediately.