想成為頂尖 Java 程序員?先過了下面這些問題

一、數(shù)據(jù)結(jié)構(gòu)與算法基礎(chǔ)

說一下幾種常見的排序算法和分別的復(fù)雜度。

用Java寫一個冒泡排序算法

描述一下鏈式存儲結(jié)構(gòu)。

如何遍歷一棵二叉樹?

倒排一個LinkedList。

用Java寫一個遞歸遍歷目錄下面的所有文件。

最后,如果大家如果在自學(xué)遇到困難,想找一個java的學(xué)習環(huán)境,可以加入我們的java學(xué)習圈,點擊我加入吧,會節(jié)約很多時間,減少很多在學(xué)習中遇到的難題。

二、Java基礎(chǔ)

接口與抽象類的區(qū)別?

Java中的異常有哪幾類?分別怎么使用?

常用的集合類有哪些?比如List如何排序?

ArrayList和LinkedList內(nèi)部的實現(xiàn)大致是怎樣的?他們之間的區(qū)別和優(yōu)缺點?

內(nèi)存溢出是怎么回事?請舉一個例子?

==和equals的區(qū)別?

hashCode方法的作用?

NIO是什么?適用于何種場景?

HashMap實現(xiàn)原理,如何保證HashMap的線程安全?

JVM內(nèi)存結(jié)構(gòu),為什么需要GC?

NIO模型,select/epoll的區(qū)別,多路復(fù)用的原理

Java中一個字符占多少個字節(jié),擴展再問int, long, double占多少字節(jié)

創(chuàng)建一個類的實例都有哪些辦法?

final/finally/finalize的區(qū)別?

Session/Cookie的區(qū)別?

String/StringBuffer/StringBuilder的區(qū)別,擴展再問他們的實現(xiàn)?

Servlet的生命周期?

如何用Java分配一段連續(xù)的1G的內(nèi)存空間?需要注意些什么?

Java有自己的內(nèi)存回收機制,但為什么還存在內(nèi)存泄露的問題呢?

什么是java序列化,如何實現(xiàn)java序列化?(寫一個實例)?

String s = new String("abc");創(chuàng)建了幾個 String Object?

三、JVM

JVM堆的基本結(jié)構(gòu)。

JVM的垃圾算法有哪幾種?CMS垃圾回收的基本流程?

JVM有哪些常用啟動參數(shù)可以調(diào)整,描述幾個?

如何查看JVM的內(nèi)存使用情況?

Java程序是否會內(nèi)存溢出,內(nèi)存泄露情況發(fā)生?舉幾個例子。

你常用的JVM配置和調(diào)優(yōu)參數(shù)都有哪些?分別什么作用?

JVM的內(nèi)存結(jié)構(gòu)?

常用的GC策略,什么時候會觸發(fā)YGC,什么時候觸發(fā)FGC?

四、多線程/并發(fā)

如何創(chuàng)建線程?如何保證線程安全?

如何實現(xiàn)一個線程安全的數(shù)據(jù)結(jié)構(gòu)

如何避免死鎖

Volatile關(guān)鍵字的作用?

HashMap在多線程環(huán)境下使用需要注意什么?為什么?

Java程序中啟動一個線程是用run()還是start()?

什么是守護線程?有什么用?

什么是死鎖?如何避免

線程和進程的差別是什么?

Java里面的Threadlocal是怎樣實現(xiàn)的?

ConcurrentHashMap的實現(xiàn)原理是?

sleep和wait區(qū)別

notify和notifyAll區(qū)別

volatile關(guān)鍵字的作

ThreadLocal的作用與實現(xiàn)

兩個線程如何串行執(zhí)行

上下文切換是什么含義

可以運行時kill掉一個線程嗎?

什么是條件鎖、讀寫鎖、自旋鎖、可重入鎖?

線程池ThreadPoolExecutor的實現(xiàn)原理?

五、Linux使用與問題分析排查

使用兩種命令創(chuàng)建一個文件?

硬鏈接和軟鏈接的區(qū)別?

Linux常用命令有哪些?

怎么看一個Java線程的資源耗用?

Load過高的可能性有哪些?

/etc/hosts文件什么做用?

如何快速的將一個文本中所有“abc”替換為“xyz”?

如何在log文件中搜索找出error的日志?

發(fā)現(xiàn)磁盤空間不夠,如何快速找出占用空間最大的文件?

Java服務(wù)端問題排查(OOM,CPU高,Load高,類沖突)

Java常用問題排查工具及用法(top, iostat, vmstat, sar, tcpdump, jvisualvm, jmap, jconsole)

Thread dump文件如何分析(Runnable,鎖,代碼棧,操作系統(tǒng)線程ID關(guān)聯(lián))

如何查看Java應(yīng)用的線程信息?

六、框架使用

描述一下Hibernate的三個狀態(tài)?

Spring中Bean的生命周期。

SpringMVC或Struts處理請求的流程。

Spring AOP解決了什么問題?怎么實現(xiàn)的?

Spring事務(wù)的傳播屬性是怎么回事?它會影響什么?

Spring中BeanFactory和FactoryBean有什么區(qū)別?

Spring框架中IOC的原理是什么?

spring的依賴注入有哪幾種方式

struts工作流程

用Spring如何實現(xiàn)一個切面?

Spring 如何實現(xiàn)數(shù)據(jù)庫事務(wù)?

Hibernate對一二級緩存的使用,Lazy-Load的理解;

mybatis如何實現(xiàn)批量提交?

七、數(shù)據(jù)庫相關(guān)

MySQL InnoDB、Mysaim的特點?

樂觀鎖和悲觀鎖的區(qū)別?

數(shù)據(jù)庫隔離級別是什么?有什么作用?

MySQL主備同步的基本原理。

select * from table t where size > 10 group by size order by size的sql語句執(zhí)行順序?

如何優(yōu)化數(shù)據(jù)庫性能(索引、分庫分表、批量操作、分頁算法、升級硬盤SSD、業(yè)務(wù)優(yōu)化、主從部署)

SQL什么情況下不會使用索引(不包含,不等于,函數(shù))

一般在什么字段上建索引(過濾數(shù)據(jù)最多的字段)

如何從一張表中查出name字段不包含“XYZ”的所有行?

MySQL,B+索引實現(xiàn),行鎖實現(xiàn),SQL優(yōu)化

Redis,RDB和AOF,如何做高可用、集群

如何解決高并發(fā)減庫存問題

mysql存儲引擎中索引的實現(xiàn)機制;

數(shù)據(jù)庫事務(wù)的幾種粒度;

行鎖,表鎖;樂觀鎖,悲觀鎖

八、網(wǎng)絡(luò)協(xié)議和網(wǎng)絡(luò)編程

TCP建立連接的過程。

TCP斷開連接的過程。

瀏覽器發(fā)生302跳轉(zhuǎn)背后的邏輯?

HTTP協(xié)議的交互流程。HTTP和HTTPS的差異,SSL的交互流程?

Rest和Http什么關(guān)系? 大家都說Rest很輕量,你對Rest風格如何理解?

TCP的滑動窗口協(xié)議有什么用?講講原理。

HTTP協(xié)議都有哪些方法?

交換機和路由器的區(qū)別?

Socket交互的基本流程?

http協(xié)議(報文結(jié)構(gòu),斷點續(xù)傳,多線程下載,什么是長連接)

tcp協(xié)議(建連過程,慢啟動,滑動窗口,七層模型)

webservice協(xié)議(wsdl/soap格式,與rest協(xié)議的區(qū)別)

NIO的好處,Netty線程模型,什么是零拷貝

九、Redis等緩存系統(tǒng)/中間件/NoSQL/一致性Hash等

列舉一個常用的Redis客戶端的并發(fā)模型。

HBase如何實現(xiàn)模糊查詢?

列舉一個常用的消息中間件,如果消息要保序如何實現(xiàn)?

如何實現(xiàn)一個Hashtable?你的設(shè)計如何考慮Hash沖突?如何優(yōu)化?

分布式緩存,一致性hash

LRU算法,slab分配,如何減少內(nèi)存碎片

如何解決緩存單機熱點問題

什么是布隆過濾器,其實現(xiàn)原理是? False positive指的是?

memcache與redis的區(qū)別

zookeeper有什么功能,選舉算法如何進行

map/reduce過程,如何用map/reduce實現(xiàn)兩個數(shù)據(jù)源的聯(lián)合統(tǒng)計

十、設(shè)計模式與重構(gòu)

你能舉例幾個常見的設(shè)計模式

你在設(shè)計一個工廠的包的時候會遵循哪些原則?

你能列舉一個使用了Visitor/Decorator模式的開源項目/庫嗎?

你在編碼時最常用的設(shè)計模式有哪些?在什么場景下用?

如何實現(xiàn)一個單例?

代理模式(動態(tài)代理)

單例模式(懶漢模式,并發(fā)初始化如何解決,volatile與lock的使用)

JDK源碼里面都有些什么讓你印象深刻的設(shè)計模式使用,舉例看看?

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 一、數(shù)據(jù)結(jié)構(gòu)與算法基礎(chǔ) 說一下幾種常見的排序算法和分別的復(fù)雜度。 用Java寫一個冒泡排序算法 描述一下鏈式存儲結(jié)...
    Java黎先生閱讀 644評論 4 10
  • 我想成為一個哲學(xué)家 去探討人存在的價值 去思索世界運行的規(guī)律 我想成為獨一無二的人 去發(fā)出新時代的吶喊 去創(chuàng)造新世...
    蝸牛嘎嘎閱讀 204評論 0 1
  • 很高興加入這個圈子,和大家一起進步,我是五月19日進入的早起群,中間出了一些意外,導(dǎo)致進群晚了,前面看沒有進群,然...
    無塵歸零閱讀 184評論 0 3
  • 國慶長假,天氣晴朗,高速免費。為了躲避假期出行擁堵,我想到了從國道第二次穿越秦嶺的計劃。(前年我沿國道210從灃峪...
    WJQ2014閱讀 1,163評論 1 9
  • 總想著,這世界一半的人成熟可靠就可以,這樣可以帶動另一半的人。但不曾設(shè)想不成熟的人依舊遇到了
    淺草不鎖閱讀 90評論 0 0

友情鏈接更多精彩內(nèi)容