[Fwd: Code review request: 7072353 JNDI libraries do not build with javac -Xlint:all -Werror]

Joe Darcy joe.darcy at oracle.com
Thu Aug 4 05:44:41 UTC 2011


David Holmes wrote:
> Joe Darcy said the following on 08/04/11 12:33:
>> David Holmes wrote:
>>>> Using wildcards makes the subtyping work along the type argument axis.
>>>
>>> So what is the right fix here? To declare the underlying Vector as a 
>>> Vector<?> and cast it to something concrete when needed? It seems 
>>> very wrong to me to be inserting raw type casts all through this code.
>>
>> It isn't entirely clear to be from a quick inspection of the code 
>> what the actual type usage is.  A writable general Vector should be a 
>> Vector<Object> and Vector just meant for reading should be a 
>> Vector<?> (or the equivalent Vector<? extends Object>).
>>
>> If the type usage is "a sequence of X's and Y's" where X and Y don't 
>> have some useful supertype, I would recommend using a somewhat 
>> different set of data structures, like a list of type-safe 
>> heterogeneous containers or a list of a new package-level XorY class.
>
> Buried in one of Sasha's emails it says:
>
> "The current code uses it to store Strings and Vector<String>s."
>
> Hence it is declared Vector<Object>.
>
> This is looking to me like code that should not have been generified.
>

Hmm.  If String or Vector<String> are the two kinds of stored values, I 
would recommend Vector<Vector<String>> where a lone string was wrapped 
in a vector.  (Actually, I would recommend a List<List<String>>, but 
that may be beyond the scope of this cleanup.

-Joe




More information about the core-libs-dev mailing list