我刚刚发现在 Java 5 里声明的一个方法:Integer.getInteger(String)
:
http://java.sun.com/j2se/1.5.0/docs/api/java/lang/Integer.html#getInteger(java.lang.String)
根据指定的名称得到系统属性的整数值。
第一个参数将被认为是系统属性的名称。系统属性可以通过
System.getProperty(java.lang.String)
方法访问得到。属性值字符串将被解释成一个整数,并且以表示这个值的Integer
对象形式返回。可能出现的数字格式的详细说明可以在getProperty
的定义说明里找到。
那么就让我来看看是否理解了:
Integer.valueOf(String)
通过假设String
表达的是一个数值而把String
转化成数字。也就是说,Integer.valueOf("12345")
得到数字12345
。Integer.getInteger(String)
通过假设String
是一个系统属性数值的名称而把String
转换成一个数字。也就是说,Integer.getInteger("12345")
应该是得到null
。
有谁会认为这两者之间有足够清晰的区别?有多少bug是因为本来想使用valueOf
但却使用了getInteger
而导致的?
这种形式的方法重载就是所谓的谐音重载(near-phrase overloading)。这是我刚发明的术语。它说的是人们使用非常相似的术语表达完全不同的东西。看一下 x
和 y
这两个词,一种情况下它们用做 gm(x)
和 gm(y)
,(译者注:gm是重量单位’克‘),而另一种上下文中它们用做 cm(x)
和 cm(y)
(译者注:cm是长度单位’厘米‘)。如果你这样使用
distance(gm(x), gm(y))<
distance(cm(x), cm(y))
那么这就是一种错误的对 x
的 y
用法!你应该在这个上下文中使用 x
和 y
之外的变量名。事实上,那个方法应该被叫做 getIntegerProperty
。
这是我在Java中看到的绝对会产生歧义一个最糟糕的案例。他们应该把事情做得漂亮些。
Update:结果我又发现了更糟糕的一个: Boolean.getBoolean("true")
得出的结果会等于 Boolean.FALSE
。
我中过这个招~~
这种情况在程序语言里比比皆是
需求中来
Bug是必然的,而不是必须的。
原来Boolean.getBoolean(“true”) 这里的参数也是系统属性
我倒没中过招,这个问题现在才注意到,呵呵。
刚刚看到,以后的注意了
Integer.getInteger(String) 通过假设 String 是一个系统属性数值的名称而把 String 转换成一个数字。也就是说, Integer.getInteger(“12345”) 应该是得到 null。??比如说????