हालांकि ऐसे वैध मामले हो सकते हैं जहां इस तरह की विधि अधिभार अस्पष्ट हो सकता है, संकलक कोड क्यों नहीं हटाता है जो न तो संकलन के समय में अस्पष्ट है और न ही रन समय पर?
उदाहरण:
// This fails:
def foo(a: String)(b: Int = 42) = a + b
def foo(a: Int) (b: Int = 42) = a + b
// This fails, too. Even if there is no position in the argument list,
// where the types are the same.
def foo(a: Int) (b: Int = 42) = a + b
def foo(a: String)(b: String = "Foo") = a + b
// This is OK:
def foo(a: String)(b: Int) = a + b
def foo(a: Int) (b: Int = 42) = a + b
// Even this is OK.
def foo(a: Int)(b: Int) = a + b
def foo(a: Int)(b: String = "Foo") = a + b
val bar = foo(42)_ // This complains obviously ...
क्या कोई कारण है कि इन प्रतिबंधों को थोड़ा ढीला नहीं किया जा सकता है?
विशेष रूप से जब अत्यधिक ओवरलोडेड जावा कोड को स्काला डिफॉल्ट तर्कों में परिवर्तित करना बहुत महत्वपूर्ण होता है और जावा के बहुत सारे तरीकों को एक स्काला विधियों द्वारा बदलने के बाद यह पता लगाना अच्छा नहीं होता है कि ऐनक / कंपाइलर मनमाना प्रतिबंध लगाता है।
object Test { def a[A](b: Int, c: Int, d: Int = 7): Unit = {}; def a[A](a:String, b: String = ""): Unit = {}; a(2,3,4); a("a");}