摘要:
线程是程序执行流的最小单位,一个进程可以有多个线程。 阅读全文
摘要:
1.iterator遍历linkedlist集合 这里可以看见Iterator li = list.iterator(); 那么这个iterator()方法是在它的抽象父类中,通过new Itr();去实例化这个Iterator对象。 这里cursor初始化值为0; 当cursor等于size的时候 阅读全文
摘要:
实现源码 这里可以看见当我们new一个hashset时,实际上hashset类又创建了一个hashmap对象map。 当我们调用add方法时,实际上add(e)对象e作为map的key值,因为map的key不允许重复,所以set集合不允许重复元素,因为hashtable算法实现原理所以set集合也是 阅读全文
摘要:
注:以下内容并非基于最新的jdk版本 q1:hashmap为什么叫hashmap? 答:hashmap基于hashtable(不是hashtable类)实现。 q2:hashtable(不是hashtable类)又什么? 答:hashtable是一个数组加链表的数据结构,以下使用hashmap举例说 阅读全文
摘要:
1.hashcode的作用? hashcode代表对象的特征,在集合类中广泛的使用。 2.hashcode是如何生成的? 在普通的对象中,获得对象的内存的地址,经过一些算法,不同对象生成不同的hashcode 字符串类型,它会根据字符串的内容,生成相关的hashcode Integer类型,返回数字 阅读全文
摘要:
1.与运算&,同为1为1,否则为0; 例如:10001(二进制)&10000(二进制)=10000(二进制) 2.或运算|,只要有1就是1; 例如:10001(二进制)&10000(二进制)=10001(二进制) 3.非运算~,1为0,0为1; 例如:~10001(二进制)=01110(二进制) 4 阅读全文
摘要:
看代码! 就是说i=8+j++ 等价于 i=8+j然而这时候j已经等于j+1了。 那么 i = 8+ ++j等价于 i = 8+(j+1)这时候j已经等于j+1了。 阅读全文
摘要:
LinkedList底层的实现基于双向表 next指向下一个node的地址。prev指向上一个node。 这里的代码是LinkedList类的源码。 那么当我们是用list.add(e);方法时会添加到这个链表的末位 那么链表的首尾node的prev和next,看实现代码 也就是说,firstnod 阅读全文
摘要:
有参构造的用处在于构造一个对象的同时初始化它的属性。 阅读全文
摘要:
源起:查看COLLECIOTNS类 Q1:为什么java需要泛型? 因为java对于对象类型的确认在编译期,那么强制类型转换就可以通过编译,但是运行时的错误却无法避免,那么泛型的存在可以避免强制类型转换的出现。 我的理解,泛型作用于一个对象的属性。 Q2:网上谈到A<Number>及B<Intege 阅读全文