Por desgracia sí.
void MyParameterizedFunction(String param1, int param2, bool param3=false) {}
podría escribirse en Java 1.5 como:
void MyParameterizedFunction(String param1, int param2, Boolean... params) {
assert params.length <= 1;
bool param3 = params.length > 0 ? params[0].booleanValue() : false;
}
Pero si debe o no depender de cómo se siente acerca del compilador que genera un
new Boolean[]{}
para cada llamada
Para múltiples parámetros predeterminados:
void MyParameterizedFunction(String param1, int param2, bool param3=false, int param4=42) {}
podría escribirse en Java 1.5 como:
void MyParameterizedFunction(String param1, int param2, Object... p) {
int l = p.length;
assert l <= 2;
assert l < 1 || Boolean.class.isInstance(p[0]);
assert l < 2 || Integer.class.isInstance(p[1]);
bool param3 = l > 0 && p[0] != null ? ((Boolean)p[0]).booleanValue() : false;
int param4 = l > 1 && p[1] != null ? ((Integer)p[1]).intValue() : 42;
}
Esto coincide con la sintaxis de C ++, que solo permite parámetros predeterminados al final de la lista de parámetros.
Más allá de la sintaxis, existe una diferencia en la que esto ha llevado a cabo la comprobación del tipo de tiempo para los parámetros predeterminados pasados y el tipo C ++ los verifica durante la compilación.
public MyParameterizedFunction(String param1, int param2)
es un constructor, no un método, una declaración.