由一个简单的String c=a+b的Java问题引发一点想法
来源:互联网 发布:淘宝正义哥卖假货么 编辑:程序博客网 时间:2024/06/05 06:41
今天在我的一个qq群里有人问了这样一个问题。
private static String a; private static String b; public static void main(String[] args) { String c = a+b; System.out.println(c); }
输出是”nullnull”。问为什么是这样。
其实问题并不复杂,很多同学也觉得自己知道原因,遂不予关注。但是我相信还是有初学Java的同学在这里是存在误会的。很典型的误会就是如一个群里的朋友说的String类型的变量如果没有显示初始化,默认的值就是”null”。支持的理由就是
private static String a; public static void main(String[] args) { System.out.println(a); }
输出是“null”。
这个现实确实很容易迷惑一些初学的人,包括我也忽略了挺久。其实呢证明这种想法错误很简单。如果默认值是“null”,那么就意味着,该变量不是空(null)。而是字符串的”null”。
private static String a; public static void main(String[] args) { System.out.println(a==null); System.out.println("null".equals(a)); }
上述代码输出分别是true,false
说明String类型变量a,其实是空(null),而并没有被赋值。那么打印出null是为什么呢?我们查看PrintStream的源码就很清晰的明白了,其实是Java在println的时候进行了处理。
public void print(String s) { if (s == null) { s = "null"; } write(s); }
回到开头的问题,既然没有初始化赋值sducc1123,那么输出为什么是”nullnull”,两个”null”连接的结果呢。这里略微细说一下,查看编译过的class文件,我们可以看到
public static void main(java.lang.String[] args); 0 new java.lang.StringBuilder [19] 3 dup 4 getstatic cn.home.pratice.jdk.string.StringMain.a : java.lang.String [21] 7 invokestatic java.lang.String.valueOf(java.lang.Object) : java.lang.String [23] 10 invokespecial java.lang.StringBuilder(java.lang.String) [29] 13 getstatic cn.home.pratice.jdk.string.StringMain.b : java.lang.String [32] 16 invokevirtual java.lang.StringBuilder.append(java.lang.String) : java.lang.StringBuilder [34] 19 invokevirtual java.lang.StringBuilder.toString() : java.lang.String [38] 22 astore_1 [c] 23 getstatic java.lang.System.out : java.io.PrintStream [42] 26 aload_1 [c] 27 invokevirtual java.io.PrintStream.println(java.lang.String) : void [48] 30 return System.out.println(c);http://guipingfuzhuang.com }
String的相加实际在变异后被处理成了StringBuilder的append.(注:我的JDK是1.6.0_u29)。那么好,我们就应该查看StringBuilder的源码,发现是调用的父类里的方法,继续查看,道理就在这里。
public StringBuilder append(String str) { super.append(str); return this; } public AbstractStringBuilder append(String str) { if (str == null) str = "null"; int len = str.length(); if (len == 0) return this; int newCount = count + len; if (newCount > value.length) expandCapacity(newCount); str.getChars(0, len, value, count); count = newCount; return this; }
原来也是对空null,进行了特殊的处理,那么输出是”nullnull”,自然也就明白了。
这里我想说的是,很多问题,可能表面上很简单,或者我们可能会有很多想当然的想法,不过还是眼见为实,而且所有代码都放在那里,我们为什么不勤快的多翻开看看其中的实现,道理自然就在眼前。多动手,丰衣足食:)
- 由一个简单的String c=a+b的Java问题引发一点想法
- 由一个简单的String c=a+b的Java问题引发一点想法
- 一点简单的想法
- HDU 3293 由简单排序引发出的一点思考
- 由一个问题引发的思考
- 一个由sizeof引发的问题
- C/C++ 由fopen_s引发的问题
- 一个问题引发的一点思考
- 由<a href = "#" > 引发的思考
- Java 数组 int[] a int[] b ,(假设 a , b 都已经实例化)引发的问题。
- 一个简单的集合并级取反问题 !A or !B == !(A and B)
- 由String s=new String ("abc");引发的联想
- c语言由一个小问题引发的关于gets和scanf的探究
- 一点由字符串匹配引发的思考
- 由SpringJdbc引发的一点思考
- 由SpringJdbc引发的一点思考
- 由a+b问题想到的
- 由一个浮点数问题引发的致命问题
- Android应用复习一_布局
- NOIP2013第一题
- uva11992
- Go into, Hongxiutianxiang
- Android与标准Linux对比
- 由一个简单的String c=a+b的Java问题引发一点想法
- 【linux + lighttpd + php + zeromq】之实战训练一
- 【ACM训练计划】 《算法艺术与信息学竞赛》题目出处 (POJ等)
- 简单记事本及目录树形图的Java实现
- C++5中内存分配方法,堆 栈 静态存储区 全局/静态变量 自由存储区
- 破解手机的任意收费游戏
- 解决dns劫持,网页重定向114
- Android Handler的机制和原理(二)
- Composite——组合模式