On Fri, 5 Dec 2025 22:37:18 GMT, Chen Liang <[email protected]> wrote:

> The 3 methods to determine conversions and subtyping on `java.lang.Class`, 
> which are `isInstance`, `cast`, and `isAssignableFrom`, have their 
> documentation from the earliest days of the Java Platform. During the 
> language evolution, a lot of terms have become inaccurate, such as 
> "assignment-compatible", which does not apply for primitive types, and the 
> out-of-date instanceof analogy with the upcoming patterns, in `isInstance`; 
> `isAssignableFrom` is not very clear about arrays; `cast` would also benefit 
> from more detailed explanations.
> 
> In my facelift, I moved the subtyping description to `isAssignableFrom`, and 
> left the conversion stuff in `isInstance` and `cast`.  I intentionally 
> avoided linking to too many JLS chapters to reduce confusions. I believe in 
> this shape, we have a good amount of easily comprehensible yet accurate 
> specification for all 3 methods, and users are welcome to read the linked JLS 
> chapters for more details and context.

This pull request has been closed without being integrated.

-------------

PR: https://git.openjdk.org/jdk/pull/28684

Reply via email to