Android没法System.out.println出null

探讨了在Android中使用System.out.println()方法打印null值时遇到的空指针异常问题及源码分析。

Android没法System.out.println出null

android无法system.out.println出null
com.android.internal.os.LoggingPrintStream.println(LoggingPrintStream.Java:298)
抛出空指针异常,NullPointerException,奇怪了,我没有调用这个方法啊,只是
System.out.println()出字符串信息?难不成println空指针字符串会出错为了验证这个问题,我特地写了如下代码再onCreate()里:

String responseBody = null;System.out.println(responseBody);

当启动的时候你发现什么了,果然是应用程序异常退出,然后看到logcat里报空指针错误,天啊!怎么会这样。看了一下源码

294 @Override295 public synchronized void println(String s) {296 if (builder.length() == 0) {297 // Optimization for a simple println.298 int length = s.length();299300 int start = 0;....
天啊,这段代码竟然没有判断s是否为空指针而直接取length了,难怪会报异常,希望android源码开发者们能看到这个问题,并且改正,要不然每一次在System.out.println()都要判断是否为空指针是多么可怕的事情啊!

android无法 system.out.println出null
com. android.internal.os.LoggingPrintStream.println(LoggingPrintStream. Java:298)
抛出空指针异常,NullPointerException,奇怪了,我没有调用这个方法啊,只是
System.out.println()出 字符串信息?难不成println空指针字符串会出错为了验证这个问题,我特地写了如下 代码再onCreate()里:

String responseBody = null;System.out.println(responseBody);

当启动的时候你发现什么了,果然是应用程序异常退出,然后看到logcat里报空指针错误,天啊!怎么会这样。看了一下源码

294 @Override295 public synchronized void println(String s) {296 if (builder.length() == 0) {297 // Optimization for a simple println.298 int length = s.length();299300 int start = 0;....
天啊,这段代码竟然没有判断s是否为空指针而直接取length了,难怪会报异常,希望android源码开发者们能看到这个问题,并且改正,要不然每一次在System.out.println()都要判断是否为空指针是多么可怕的事情啊!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值