Java Compile error: Parameter x is exceeding the l

2020-04-07 05:31发布

问题:

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.

回答1:

Well you're breaking the VM specification, section 4.10:

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.



回答2:

There are 2 options to resolve this problem:

  1. Generate your class with no or some constructor arguments and then set rest parameters via setters. Like using builder pattern.
  2. Make simpler classes each holding 3 or 4 variables and set those simpler objects in 1 master class.


回答3:

Well, the class file spec. says:

A method descriptor is valid only if it represents method parameters with a total length of 255 or less, where that length includes the contribution for this in the case of instance or interface method invocations. The total length is calculated by summing the contributions of the individual parameters, where a parameter of type long or double contributes two units to the length and a parameter of any other type contributes one unit.