这个问题也不算什么有技术含量的问题,不过我感觉还是有必要写篇博客记录,以免有人遇到和我一样的困扰,也是因为在网上搜索发现,没有多少文章说明这个如题的原因,可能是大多都没经历过这个问题,或者是感觉不值得一写。
背景:有一次在调试程序的时候,我打印List集合中的内容,但是发现打印出来的结果条数总是比List的size()方法返回值要小,重复了多少次都是一样,找了一会原因没找到,后来不了了之。
结果,没过多久,又遇到一样的情况:
这次的现象是我往集合中添加了重复的数据,然后打印发现无论重复数据添加多少,在logcat中打印的时候最多只能打印出两条,自然打印结果的总条数也比List的size方法要小,我想难道是List新加了去重的属性?但是如果去重为啥能显示两条?我尝试看了一下源码以及搜了一下, 很快推翻这个想法。
然后想,难道是Log本身加了新的特性,不能打印重复数据?然后我用System.out.print尝试打印,结果能正常打印,这就印证了我的假设,剩下就是找证据了。然后我就选择Log的一个方法点进去追sdk中的代码,结果追了几步就没法追了,因为只能看到下边截图中的情况,再往后找不到了。
最后,我只能搜索其他的文章了。结果,虽然这种文章很少,但确实已经有人写了,请参考&#x