Java基础之Void类的源码分析
2017-12-14 18:14
381 查看
市场上技术书籍很少介绍的Void,其实Void是一种基本的数据类型。位于java.lang.Void,
源码内容不多,附上源码比较好理解些。
对照着源码深入剖析它:
首先,看源码的注释我们知道,Void类型不能实例化是一个占位符的类,void是java的一个关键字。这两者是有区别的。Void类是给void关键字提供一个不能实例化的一个占位符的作用。
分析一下,
(1)不能实例化是因为Void类的修饰词是final,一经设置不能改变引用当然不能实例化它啊,实例化的前提要引用可以改变。同时它的构造函数是私有的,就不可能被实例化。
(2)为什么Void类是给void关键字提供一个不能实例化的一个占位符的作用?
看源码
这行代码就是利用泛型把Void类与void关键字关联起来,是为了表示Void是void一个占位符的作用。
源码内容不多,附上源码比较好理解些。
package java.lang; /** * The {@code Void} class is an uninstantiable placeholder class to hold a * reference to the {@code Class} object representing the Java keyword * void. * * @author unascribed * @since JDK1.1 */ public final class Void { /** * The {@code Class} object representing the pseudo-type corresponding to * the keyword {@code void}. */ @SuppressWarnings("unchecked") public static final Class<Void> TYPE = (Class<Void>) Class.getPrimitiveClass("void"); /* * The Void class cannot be instantiated. */ private Void() {} }
对照着源码深入剖析它:
首先,看源码的注释我们知道,Void类型不能实例化是一个占位符的类,void是java的一个关键字。这两者是有区别的。Void类是给void关键字提供一个不能实例化的一个占位符的作用。
分析一下,
(1)不能实例化是因为Void类的修饰词是final,一经设置不能改变引用当然不能实例化它啊,实例化的前提要引用可以改变。同时它的构造函数是私有的,就不可能被实例化。
(2)为什么Void类是给void关键字提供一个不能实例化的一个占位符的作用?
看源码
public static final Class<Void> TYPE = (Class<Void>) Class.getPrimitiveClass("void");
这行代码就是利用泛型把Void类与void关键字关联起来,是为了表示Void是void一个占位符的作用。
相关文章推荐
- Java基础——HashTable源码分析
- java基础--ThreadPoolExecutor源码分析
- java基础提高篇--集合源码分析--jdk1.8 HashMap源码
- Java基础——Vector源码分析
- 【JAVA基础】集合类源码分析_HashMap/HashSet
- Java基础——LinkedHashMap源码分析
- 【JAVA基础】集合类源码分析_ArrayList
- java核心基础--jdk源码分析学习--基本数据类型
- Java源码分析:深入探讨Iterator模式-Java基础-Java-编程开发
- java源码分析之TreeMap基础篇
- java核心基础--jdk源码分析学习--LinkedList
- java源码分析之TreeMap基础篇
- java核心基础--jdk源码分析学习--String
- java基础解析系列(十)---ArrayList和LinkedList源码及使用分析
- Java基础——LinkedList源码分析
- java核心基础--jdk源码分析学习--Integer
- Java基础——HashMap源码分析
- 【Java】Java基础知识之HashMap源码分析(Java8)
- Java基础——HashSet源码分析
- java基础提高篇--集合源码分析--jdk1.8 ArrayList源码