JavaBase-2

前序:大多数成功的人赢在时间管理上。最近在考虑时间规划的问题,小到每天,大到每年,我们如何在有限的生命中,去掌握那无限的知识,讲到这里我想起一个人达芬奇,真是开挂的一生,只要他感兴趣的领域,他就能成为这个领域的专家,感兴趣的朋友可以了解一下他一生的成就。上篇博文提到了迷失,这篇说说如何让自己的定位及目标更清晰,我们要有一点善于归纳总结的能力,在一个领域三到五年或多或少能说出自己理解的一些东西,即使再笨多人耳濡目染的也会在自己大脑里形成一些片段性的知识,为什么说是片段性的知识,因为所有领域都像一个无限延伸的树网,由节点开始慢慢的往四周蔓延,也会交叉到其他的领域的网树,如果不你停下来总结一下,你了解的只是网树的一部分,或者说是一个小分支,很难从全局角度考虑,你在这树网中处于什么位置,如果你有幸接触一些,反而有种掉入树网中的感觉,你接触的信息和你以前掌握的知识短节了,你所在的节点连不到你掌握的节点,所以你迷失了,都不知道从何学起。那我们现在何不把自己熟悉领域的知识网给画出来,搭建属于自己的一套知识体系架构,找出你职业所需知识的架构主干,然后把知识从初级到中级到高级逐级的掌握,来丰富自己搭建的知识体系。本篇还是会从基础谈起,因为个人感觉,以后我可能展开的JDK源码解析、中间件源码解析,所有的一切一切,都离不开数据结构和算法,所以要把基础的东西学扎实,达到面试中所提到的要求-有扎实的基础。


2.特殊方法说明

2.1 Object基类方法说明

getClass() 

类的加载机制 双亲委派的好处 tomcat类加载机制

加载的类信息都可以来自哪里?

    equals()

对称:x.equals(y) y.equals(x) 结果一样

反射:x.equals(x) == true

类推:x.equals(y) y.equals(z) ->z.equals(x)

一致:x.equals(y) 执行多少次 结果不变

x.equals(null) == false;x.equals(和x不同类型的对象)==false

Java约定的规范原则1、如果两个对象相同,那么它们的hashCode值一定要相同;2、如果两个对象的hashCode相同,它们并不一定相同

为什么覆写equals的时候一定要覆写hashCode?

如果class不可能放在hash code为基础的容器内,不必override hashCode(),

例如HashMap和Hashtable里面如果是作为value而不是作为key的话也是不必override hashCode了

如果放在对象做了hashcode的操作,反而没有override hashCode(),会出现一下两种情况

1、如果equals为true hashCode不等的b作为get参数的话,这个时候b算出来的数组下标一定不是a所在的下标位置

2、如果equals为false hashCode相等的b作为get参数的话,这个时候b算出来的数组下标是对了,但是用equals来寻找相符的key了

混乱的根本就是错误实现hashCode和equals,所以说必须按照约定的规范来。

    hashCode()

native方法 JVM生成的标识此对象的一个整形数据

String的hashCode算法?s[0]*31^(n-1)+s[1]*31^(n-2)……..+s[n-1]->h=31*h+val[i]

hash冲突的解决办法?1、地址链法(HashMap key冲突后会在在所在冲突索引处的节点上形成单向链表)

HashMap的Hash函数为什么要这么设计,HashTable呢 int index = (hash & 0x7FFFFFFF) % tab.length;

为什么先判断hashcode,在判断equals()?

    toString()

getClass().getName() + “@” + Integer.toHexString(hashCode()); 类的全限定名 + @ + 十进制的哈希码转换为16进制的

    wait() wait(time) wait(time,nanos) notify() notifyAll()

wait和sleep有什么区别

Thread.sleep()与Object.wait()二者都可以暂停当前线程,释放CPU控制权,主要的区别在于Object.wait()在释放CPU同时,释放了对象锁的控制。

调用Thread的wait方法含义

wait的参数,一个参数和两个参数的区别 怎么判断wait是超时返回还是其他线程通知返回的呢? 

设置全局标记 在其他线程中修改标记 对超时时间进行判断 如果线程wait结束的时间大于等于超时时间 说明是超时的

怎么查看处于wait状态的线程  jstack

    clone()

浅拷贝,深拷贝

clone怎么做深拷贝,还有其他方式做深拷贝么 序列化

为什么java已经有了clone方法,还要实现一个Cloneable接口呢 Cloneable接口是不包含任何方法的!

其实这个接口仅仅是一个标志,而且这个标志也仅仅是针对 Object类中clone()方法的,如果clone类没有实现Cloneable接口,

并调用了Object的clone()方法(也就是调用了 super.Clone()方法),那么Object的clone()方法就会抛出CloneNotSupportedException异常。

类似Serializable接口,接口也是空的,实现序列化操作类必须实现此接口。

    finalize()

怎么阻止一个非根引用对象被回收? 接到根引用对象上

一个空的Object占用多少内存,如果里面有空的boolean和int呢

32bit系统 和 64 bit系统的区别

64bit JVM是否开启指针压缩的区别

对象头    16 12

基本数据  不变

引用类型  8 4 

数组      24 16

参考 http://www.cnblogs.com/magialmoon/p/3757767.html


评论已关闭。