本文适合的人群

其实感觉写这个标题的内容没有必要,只要你觉得对你有帮助那么就适合你,对你没帮助那么就不适合你.毕竟我不是专业作者,但咱会尽力的.其实最重要的一点是我不希望浪费您宝贵时间.

简要把内容在这里说一下(等会弄目录了,再改成目录方式吧)

  1. 对java.lang.Boolean的概况简单介绍.这里其实和看API差不多,而且没有API全.
  2. 我个人是如何理解java.lang.Boolean的
  3. 拆箱和装箱

我衷心的希望您能提出宝贵的意见,若文中有任何不妥非常希望能得到您的指正.

java.lang.Boolean主要概况

类描述

  1. public final class Boolean implements java.io.Serializable,Comparable<Boolean>

成员变量

  1. public static final Boolean TRUE = new Boolean(true);
  2. public static final Boolean FALSE = new Boolean(false);
  3. public static final Class<Boolean> TYPE = Class.getPrimitiveClass("boolean");
  4. private final boolean value;
  5. private static final long serialVersionUID = -3665804199014368530L;

构造器

  1. public Boolean(boolean value) {
  2.   this.value = value;
  3. }
  4. public Boolean(String s) {
  5.   this(toBoolean(s));
  6. }

简单的理解源代码

从类描述中可以看到java.lang.Boolean使用了final关键字声明,并且仅有的5个成员变量也都使用了final关键字声明.因此

java.lang.Boolean 不允许继承并且一旦构造完毕,它的状态不可改变.

java.lang.Boolean类是基本类型boolean的包装类,既然是包装类那么java.lang.Boolean类中一定会包含一个boolean的基本类型成员变量.

在源码中它是这样声明的private final boolean value;

成员变量value被声明为final,又没给定初始值,这种情况被称为"空白final".

语法上规定必须确保在使用"空白final"变量前被初始化.因此不在成员变量定义的时候初始化那么就只能在构造器里初始化了.其实也可以在构造代码块中对"空白final"进行初始化.

java.lang.Boolean提供了两个构造器

  • 使用基本类型的boolean初始化.
    既然你是包装基本类型boolean的,那我直接传给你一个基本类型,你给我包装就行了.
  • 使用java.lang.String类型初始化
    同时还可以用字符串对象构造一个java.lang.Boolean.规则很简单,只要"true".equalsIgnoreCase(param)就可以.

在类定义中有两个静态常量,他们分辨代表java.lang.Boolean类型的true和false.

  1. //代表true的java.lang.Boolean类型
  2. public static final Boolean TRUE = new Boolean(true);
  3. //代表false的java.lang.Boolean类型
  4. public static final Boolean FALSE = new Boolean(false);

我们都知道正常情况下当使用new关键字时,总会在内存中创建一个新的对象.

同样我们的程序只要执行了new Boolean(true);或new Boolean(false);都会在内存中创建一个对象.如果对于资源比较紧张的部署环境来讲,这种操作其实是很致命的.

其实我们完全可以考虑使用TRUEFALSE两个静态常量,简单实用.看一段代码.

  1. public static void main(String[] args) {
  2. Boolean b1 = new Boolean(true);
  3. Boolean b2 = new Boolean(false);
  4. //输出"b1:true,b2:false"
  5. System.out.println("b1:" + b1 + ",b2:" + b2);
  6.  
  7. Boolean b3 = new Boolean(true);
  8. //输出"false"
  9. System.out.println(b1 == b3);
  10.  
  11. //下面使用java.lang.Boolean的静态常量TRUE和FALSE
  12. Boolean b4 = Boolean.TRUE;
  13. Boolean b5 = Boolean.FALSE;
  14. //输出"b4:true,b5:false"
  15. System.out.println("b4:" + b4 + ",b5:" + b5);
  16.  
  17. Boolean b6 = Boolean.TRUE;
  18. //输出"true"
  19. System.out.println(b4 == b6);
  20. }

上面的代码只是通过调用静态成员来获得对应的java.lang.Boolean对象,很多时候,都会根据参数来获得相应对象.再看一段代码.

  1. public static void main(String[] args) {
  2. //Boolean.valueOf(boolean)的使用
  3. Boolean b1 = Boolean.valueOf(true);
  4. Boolean b2 = Boolean.valueOf(false);
  5. //输出"b1:true,b2:false"
  6. System.out.println("b1:" + b1 + ",b2:" + b2);
  7.  
  8. Boolean b3 = Boolean.valueOf(true);
  9. //输出"true"
  10. System.out.println(b1 == b3);
  11.  
  12. //Boolean.valueOf(String)的使用
  13. Boolean b4 = Boolean.valueOf(null);
  14. Boolean b5 = Boolean.valueOf("yes");
  15. Boolean b6 = Boolean.valueOf("tRue");
  16. //输出"b4:false,b5:false,b6:true"
  17. System.out.println("b4:" + b4 + ",b5:" + b5 + ",b6:" + b6);
  18.  
  19. Boolean b7 = Boolean.valueOf("TRUE");
  20. //输出"true"
  21. System.out.println(b6 == b7);
  22.  
  23. //输出"true"
  24. System.out.println(b1 == b7);
  25. }

阅读源代码的威力要体现出来了,不懂结果的朋友们不要着急baidu、google.花点时间读读源代码,耐心去看,一定能看懂.

我先贴几段相关的代码,看看上面的输出是怎么回事.

  1. public static final Boolean TRUE = new Boolean(true);
  2. public static final Boolean FALSE = new Boolean(false);
  3.  
  4. public static Boolean valueOf(boolean b) {
  5. return (b ? TRUE : FALSE);
  6. }
  7. public static Boolean valueOf(String s) {
  8. return toBoolean(s) ? TRUE : FALSE;
  9. }
  10.  
  11. //java.lang.String参数的构造也是调用的这个方法
  12. //其实就是"true".equalsIgnoreCase(name)
  13. //忽略了大小写,判断是不是个true字符串
  14. private static boolean toBoolean(String name) {
  15. return ((name != null) && name.equalsIgnoreCase("true"));
  16. }

自动装箱和拆箱

自动装箱和拆箱我贴出两段代码,大家自己来分析一下.

  1. //java源代码
  2. public static void main(String[] args) {
  3.   Boolean b1 = true;
  4.   Boolean b2 = false;
  5.   boolean b3 = Boolean.TRUE;
  6.   boolean b4 = Boolean.FALSE;
  7.   System.out.println(b1 == b3);
  8.   System.out.println(b2 == b4);
  9. }
  10.  
  11. //通过反编译工具,对上面的代码class文件的反编译结果
  12. public static void main(String[] args) {
  13.   Boolean b1 = Boolean.valueOf(true);
  14.   Boolean b2 = Boolean.valueOf(false);
  15.   boolean b3 = Boolean.TRUE.booleanValue();
  16.   boolean b4 = Boolean.FALSE.booleanValue();
  17.   System.out.println(b1.booleanValue() == b3);
  18.   System.out.println(b2.booleanValue() == b4);
  19. }

其实还有一个办法就是通过eclipse + debug.有兴趣的朋友可是去试试.

如果你的JDK不带 debug信息,在跟踪源代码的时候会看不到变量的状态.

解决办法可以看http://www.cnblogs.com/sealedbook/p/3442334.html

JDK1.7.0_45源码阅读<java.lang.Boolean>的更多相关文章

  1. jdk源码分析——java.lang.Boolean

      1.Boolean类里面的2个静态变量. Boolean类,直接声明了2个静态变量,TRUE 和 FALSE,指向2个对象.     public static final Boolean TRU ...

  2. jdk1.8.0_45源码解读——Set接口和AbstractSet抽象类的实现

    jdk1.8.0_45源码解读——Set接口和AbstractSet抽象类的实现 一. Set架构 如上图: (01) Set 是继承于Collection的接口.它是一个不允许有重复元素的集合.(0 ...

  3. jdk1.8.0_45源码解读——LinkedList的实现

    jdk1.8.0_45源码解读——LinkedList的实现 一.LinkedList概述 LinkedList是List和Deque接口的双向链表的实现.实现了所有可选列表操作,并允许包括null值 ...

  4. jdk1.8.0_45源码解读——HashSet的实现

    jdk1.8.0_45源码解读——HashSet的实现 一.HashSet概述 HashSet实现Set接口,由哈希表(实际上是一个HashMap实例)支持.主要具有以下的特点: 不保证set的迭代顺 ...

  5. jdk1.8.0_45源码解读——HashMap的实现

    jdk1.8.0_45源码解读——HashMap的实现 一.HashMap概述 HashMap是基于哈希表的Map接口实现的,此实现提供所有可选的映射操作.存储的是<key,value>对 ...

  6. jdk1.8.0_45源码解读——Map接口和AbstractMap抽象类的实现

    jdk1.8.0_45源码解读——Map接口和AbstractMap抽象类的实现 一. Map架构 如上图:(01) Map 是映射接口,Map中存储的内容是键值对(key-value).(02) A ...

  7. jdk1.8.0_45源码解读——ArrayList的实现

    jdk1.8.0_45源码解读——ArrayList的实现 一.ArrayList概述 ArrayList是List接口的可变数组的实现.实现了所有可选列表操作,并允许包括 null 在内的所有元素. ...

  8. 【JDK1.8】JDK1.8集合源码阅读——总章

    一.前言 今天开始阅读jdk1.8的集合部分,平时在写项目的时候,用到的最多的部分可能就是Java的集合框架,通过阅读集合框架源码,了解其内部的数据结构实现,能够深入理解各个集合的性能特性,并且能够帮 ...

  9. 如何阅读Java源码 阅读java的真实体会

    刚才在论坛不经意间,看到有关源码阅读的帖子.回想自己前几年,阅读源码那种兴奋和成就感(1),不禁又有一种激动. 源码阅读,我觉得最核心有三点:技术基础+强烈的求知欲+耐心.   说到技术基础,我打个比 ...

随机推荐

  1. 【WPF】日常笔记

    本文专用于记录WPF开发中的小细节,作为备忘录使用. 1. 关于绑定: Text ="{Binding AnchorageValue,Mode=TwoWay,UpdateSourceTrig ...

  2. Android—Volley:接收服务端发送的json数据乱码问题解决

    new JsonObjectRequest中重写方法parseNetworkResponse,内容如下: /** * 重写此方法不会导致乱码 */ @Override protected Respon ...

  3. firebug不能加载JS文件 ,无法进行JS脚本调试

    提示: 本页面不包含 Javascript 如果 <script> 标签有 "type" 属性,其值应为 "text/javascript" 或者& ...

  4. [原创]ubuntu16.04LTS使用细节

    如何给自己安装的应用创建桌面图标 拿php开发神器phpstorm为例,找到可执行文件所在路径. 这里是/home/haive/PhpStorm/bin/phpstorm.sh 打开dash,搜索&q ...

  5. Linux实战教学笔记06:Linux系统基础优化

    第六节 Linux系统基础优化 标签(空格分隔):Linux实战教学笔记-陈思齐 第1章 基础环境 第2章 使用网易163镜像做yum源 默认国外的yum源速度很慢,所以换成国内的. 第一步:先备份 ...

  6. 如何查看w3p.exe 和IIS 应用程序池的关系

    图形界面方式 命令行方式 如果找不到 appcmd Appcmd.exe exists at the location %systemroot%\system32\inetsrv\. You eith ...

  7. sublime text 3 + python配置,完整搭建及常用插件安装

    四年的时间,一直使用EmEditor编辑器进行Python开发,之前是做面向过程,只需要将一个单独的py文件维护好即可,用着也挺顺手,但是最近在做面向对象的开发,不同的py文件中相互关联较多,感觉单纯 ...

  8. 【流量劫持】沉默中的狂怒 —— Cookie 大喷发

    精简版:http://www.cnblogs.com/index-html/p/mitm-cookie-crack.html 前言 上一篇文章 讲解了如何借助前端技术,打造一个比 SSLStrip 更 ...

  9. 使用C# 和Consul进行分布式系统协调

    随着大数据时代的到来,分布式是解决大数据问题的一个主要手段,随着越来越多的分布式的服务,如何在分布式的系统中对这些服务做协调变成了一个很棘手的问题.今天我们就来看看如何使用C# ,利用开源对分布式服务 ...

  10. 安全防范:nginx下git引发的隐私泄露问题

    安全防范:nginx下git引发的隐私泄露问题 1   安全事件 最近阿里云服务器后台管理系统中收到一条安全提示消息,系统配置信息泄露: http://my.domain.com/.git/confi ...