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

-

原创粉丝点击