第一篇写的博客给本身的学习路线立了个flag后,感受如今学习的积极性大增,这也离不开那几位老铁们的互相鼓励。废话很少说,如今给出本身总结的Java基础部分所要重点注意的内容,对之后的开发工做也是很经常使用,至少我目前的感受是这样的!对于基础的语法和数据类型,逻辑判断等相关的,若是是刚入门的话,推荐两个简单易懂的网站:菜鸟教程、w3cschool这里能够进行相关的基础知识的学习。既然是要学习,那编程工具固然是少不了的,除了经常使用的记事本、notepad++等,我想你们确定都少不了要安装一款能够运行代码的编程工具吧。学习Java的确定对eclipse和myeclipse不陌生,至于这两个有什么区别,我想度娘确定比我解释的清除。不过慢慢的工做过程当中,当我接触到intellij idea这款编程工具后,真的是如获至宝啊。想了解它有什么优点,一样找度娘,不在此篇博客范围内。html
说了这么多,其实就是告诉你们要安装一款编程软件,后期能够随时进行代码的运行验证,这里仍是建议你们先安装eclipse,由于idea里面的东西我本身都尚未彻底搞懂呢(苦笑不得),这里推荐这位老铁的搭建教程:Java开发环境搭建。好了,这下真的要进入到此次的重要内容了!java
一、Java的访问权限面试
Java中有四种访问权限:默认访问权限、public、private、protected编程
这四种访问权限中,只有默认访问权限和public才能修饰类(这里所说的类为外部类,对于内部类,四种权限均可以进行修饰),对于字段和方法,四种权限均可以进行修饰。数组
默认访问权限(字段或类前不加任何修饰符):用默认访问权限进行修饰,只能在同包中进行访问。安全
public:任何地方均可见(方法、字段、包)。并发
private:用private修饰的方法或字段只能在本类中进行访问。app
protected:用protected修饰类的方法或字段,在同包中能够被访问,对于不一样的包,只能经过继承对其方法或字段进行访问。eclipse
具体细节参考:http://www.cnblogs.com/dolphin0520/p/3734915.html,这篇博文中有详细解释。ide
二、开发过程当中不得不面临的equals和==的区别
1)对于8种基础数据类型,"=="比较值是否相等。
若是做用于引用类型的变量,则比较的是所指向对象的地址。
注:equals方法是不能做用与基础类型数据的,只能做用与引用类型数据。
2)对于equals方法:
若是equals方法未被重写,则比较的是引用类型变量所指向的对象地址。
对于String、Integer、Date等复写了equals方法的对象,则比较的是对象内容。
注:重写了equals方法的对象:String、8种基础类型的包装类、Date等,这里并未列举完。
具体参考:
http://www.javashuo.com/article/p-hbgdatxk-cs.html
http://www.cnblogs.com/dolphin0520/p/3592500.html
注:在重写equals方法时为何要同时重写hashCode方法?
具体参考:http://www.cnblogs.com/happyPawpaw/p/3744971.html
重写hashCode方法,主要是为了维护hashCode方法的协定,该协定规定,相等的对象必须有相同的哈希码。
这三个对象在平时使用和面试中出现的频次很是的高。
要点:
String是不可变对象。这点能够从String的源码中看到。
StringBuffer是线程安全的。从源码中能够看到函数上使用了synchronized进行修饰。
StringBuilder是非线程安全的。
特别指出String中的intern()方法,该方法从源代码中能够看出为本地方法(而且与jdk的版本有关系,以jdk1.6为分界点),而且在面试题中极其容易出现,具体区别为:
在jdk1.6之前:
调用intern方法时,首先会去常量池中查找是否存在与当前String值相同的值,
若是存在的话,则直接返回常量池中这个String值的引用;若是不存在的话,则会将原先堆中的该字符串拷贝一份到常量池中,并返回该字符串在常量池中的引用。
jdk1.7:
调用intern方法时,首先会去常量池中查找是否存在与当前String值相同的值,
若是存在的话,则直接返回常量池中这个String值的引用;若是不存在的话,则只会将原先堆中该字符串的引用放置在常量池中。注意:不会拷贝这个字符串到常量池中。
注意:因为jdk1.7对字符串常量池作出了调整,从PermGen区中调整到了堆中,因此在使用intern方法时,并不会进行字符串的拷贝。
下面给出相应例子,更清楚的说明intern方法。
1 String str1 = "abcd"; 2 String str2 = new String("ab") + new String("cd"); 3 System.out.println(str2.intern() == str1); 4 System.out.println(str2 == str1);
jdk1.6中输出:
false
false
jdk1.7中输出:
true
false
解释:
在jdk1.6中字符串常量池和堆区被彻底区分开,因此会返回两个false。
在jdk1.7中
在执行第1行String str1=“abcd”时,会将“abcd”直接存储到常量池中。
在执行第2行String str2=new String("ab")+new String("cd")时,在类加载的时候,会在常量池中存储"ab"和"cd"。
当执行str2.intern()方法时,发现常量池中存在"abcd"(第一行代码的结果),因此返回此时"abcd"字符串的引用,即str1,因此str2.intern()==str1为true,两处的引用相同的。
第四行,str2==str1,两个引用的地址明显不一样,str2指向堆,str1指向字符串常量池中,因此为false。
将上述代码进行变形,形式以下:
1 String str2 = new String("ab") + new String("cd"); 2 str2.intern(); 3 String str1="abcd"; 4 System.out.println(str2 == str1);
在jdk1.6中,一样输出false。
可是在jdk1.7中输出true。
解释:
在执行第1行String str2=new String("ab")+new String("cd")时,在类加载的时候,会在常量池中存储"ab"和"cd"。注意:这时常量池中是没有"abcd"的。
在执行第2行str2.intern()方法时,发现常量池中没有"abcd",因而将str2的引用放入常量池中,并不会进行拷贝。
在执行第3行时,发现常量池中已经存在"abcd"的引用了,直接赋值给str1,因此最后的结果为true。
将上述代码再次变形,将第2行与第3行互换位置。形式以下:
1 String str2 = new String("ab") + new String("cd"); 2 String str1 = "abcd"; 3 str2.intern(); 4 System.out.println(str2 == str1);
在jdk1.6与jdk1.7中都是输出false。
这个原理比较简单了,str2与str1,明显是两个不一样的引用,str2指向堆,str1指向字符串常量池,因此为false。
具体参考:
http://www.cnblogs.com/dolphin0520/p/3778589.html
http://blog.csdn.net/seu_calvin/article/details/52291082
http://www.importnew.com/14142.html
http://blog.csdn.net/bigtree_3721/article/details/74907670
http://blog.csdn.net/hzw19920329/article/details/51262925
四、集合类不得不掌握的东西
数组(能够存储基本数据类型)是用来存现对象的一种容器,可是数组的长度固定,不适合在对象数量未知的状况下使用。
集合(只能存储对象,对象类型能够不同)的长度可变,可在多数状况下使用。
要点:
List有序集合,能够包含重复元素。
Set无序(TreeSet有序,二叉树排序),不能包含重复元素。
Map不能包含重复的键值,由于键值对。
注:参考博文中说,全部集合类都实现了Iterator接口,可是Map集合是没有实现该接口的。
集合中有几个重要的对象须要特别提出来:HashMap、Hashtable、ConcurrentHashMap
这里给出两位老铁总结比较详细的博客:
http://www.javashuo.com/article/p-xtnpuchz-bp.html
HashMap的实现原理,参考:http://www.cnblogs.com/xwdreamer/archive/2012/06/03/2532832.html
注:参考博文中说,全部集合类都实现了Iterator接口,可是Map集合是没有实现该接口的。
集合中有几个重要的对象须要特别提出来:HashMap、Hashtable、ConcurrentHashMap
HashMap的主要特色:
1)非同步的,也就说是非线程安全的,与Hashtable相反。
2)无序,容许null键和null值(HashTable不容许键或值为null),不能包含重复的键,可是重复的键是能够put进HashMap集合的。
3)继承自AbstractMap,并实现了Map接口。
4)在HashMap中扩容时,是很是耗性能的;HashMap默认数据容量大小为16,loadFactor(扩容因子默认值为0.75),当元素个数大于16*0.75=12时,就会进行扩容,扩大一倍:2*16=32。
5)HashMap线程不安全的具体体现,参考:http://www.importnew.com/22011.html
HashTable的实现原理,参考:http://www.javashuo.com/article/p-dqadwfdc-eg.html
Hashtable的主要特色:
1)Hashtable是线程安全的。
2)无序,不容许null键或null值。
3)继承与Dictionary接口,也实现了Map接口。
4)Hashtable扩容时,扩大的容量为:2n*+1,扩大一倍并加1。Hashtable默认数据容量为11。
ConcurrentHashMap的实现原理,参考:
https://my.oschina.net/hosee/blog/639352
https://www.cnblogs.com/chengxiao/p/6842045.html
http://pettyandydog.com/2017/07/27/concurrentHashMap/
https://my.oschina.net/hosee/blog/675884
ConcurrentHashMap的主要特色:(基本上到目前没遇到过这个集合)
1)线程安全的,主要使用锁分离技术(分段锁)。
2)初始容量大小为16,默认并发度也为16。
3)因为使用分段锁技术,只有对于同一段数据操做,才会考虑线程同步。
4)无序,不容许null键或null值。(源码put函数能够得出该结论)
今天的博客就主要分享这几个吧,毕竟一口吃不了一个大胖子。还有点要说明一下,上述内容并不都是我本身写的,我没有那么好的文采。但这些东西绝对是我本身都认真看过以后才贴出来的,不喜勿喷,发这个的最初目的就是为了督促本身天天进步一点点就够了~by:lmyou