java源码解析
来源:互联网 发布:御剑江湖进阶数据 编辑:程序博客网 时间:2024/06/01 11:48
1、集合的toString方法的作用原理是什么呢?
我们看一下这个测试代码:
public static void main(String[] args) { Collection c = new ArrayList(); c.add("I"); c.add("am"); c.add("here"); System.out.println(c);}
输出:
[I, am, here]
现在我们就有个疑惑了,为什么打印输出c输出的不是地址而是值呢?
出现这种情况,我们应该就会猜想集合c应该是调用了toString()方法,所以才没有输出地址值。我们假设是调用了toString()方法。Collection c = new ArrayList();这是多态的用法,所以调用的也一定是ArrayList的toString方法才对。为了解决我们的疑惑,我觉得看源码是直接的方式。
于是我去ArrayList类中找toString方法,但是没有找到,那怎么办呢?只能去ArrayList类的父类中找啦,于是去它的父类AbstractList类中找,还是没有找到,于是我们就去AbstractList类的父类中找,终于在AbstractCollection类找到了toString()方法。
父- - - - - - - - - - - - - - - – - ->子
AbstractCollection - - - - - - -> AbstractList
AbstractList- - - - - - - - - - - ->ArrayList
代码如下:
public String toString() { Iterator<E> it = iterator(); //集合本身调用迭代器方法,得到集合迭代器 if (! it.hasNext()) //如果没有元素,就返回空 return "[]"; StringBuilder sb = new StringBuilder(); sb.append('['); for (;;) { E e = it.next(); //如果有元素,就进行拼接 sb.append(e == this ? "(this Collection)" : e); if (! it.hasNext()) return sb.append(']').toString(); sb.append(',').append(' '); }}
2、为什么HashSet存储字符串的时候,当字符串内容相同的时候它只存储一个值呢?
可以去看我这篇文章:http://blog.csdn.net/qq_36748278/article/details/77842660
3、TreeSet是如何保证元素的唯一性和排序的呢?
请看我这篇文章,有源码,解析的很透彻:http://blog.csdn.net/qq_36748278/article/details/77915801#t1
-
阅读全文
0 0
- JAVA源码解析-String源码
- JAVA源码解析-ArrayList源码
- JAVA源码解析-LinkedList源码
- Java源码解析-DualPivotQuicksort
- java FutureTask 源码解析
- java Collection源码解析
- Java HashMap 源码解析
- Java TreeMap 源码解析
- Java TreeMap 源码解析
- Java HashMap 源码解析
- Java TreeMap 源码解析
- Java HashMap 源码解析
- Java TreeMap 源码解析
- Java String 源码解析
- Java:HashMap源码解析
- Java源码解析-hashmap
- java String源码解析
- Java源码解析-BlockingQueue
- Oracle 之 AIO (异步io)
- WinDBG技巧:this指针的常见误区 (ECX寄存器存放this指针)
- 1050. 螺旋矩阵(25)
- VS2010&MFC对话框编程(1)——对话框控件简介
- K-means中的K值选择与初始点的选择
- java源码解析
- 线段树区间更新(2)(lazy)(区间都变为v)(序号从1开始)(O(logn))模板(hdu1698)
- Mybatis实现分页
- 网易---合唱团----动态规划
- 总结-2017/9/7
- python对象机制
- 常见的加密算法介绍
- RMQ求LCA
- JAVA设计模式之外观模式