java webservice报文过长_工作1-5年的Java程序猿到底需要怎样的一个技术栈?
工作1-5年的Java程序猿到底需要怎樣的一個(gè)技術(shù)棧?
前言:
具有1-5年開(kāi)發(fā)經(jīng)驗(yàn)的程序員 需要學(xué)習(xí)的內(nèi)容其實(shí)還有很多很多。
今天跟大家交流一下希望分享出來(lái)的對(duì)大家能夠有幫助,這是我這些年總結(jié)出的一些經(jīng)驗(yàn),相對(duì)而言比較體系,不喜勿噴:
閱讀時(shí)間十分鐘左右,文末贈(zèng)學(xué)習(xí)資料!
一、數(shù)據(jù)結(jié)構(gòu)與算法基礎(chǔ)
1.說(shuō)一下幾種常見(jiàn)的排序算法和分別的復(fù)雜度。
2.用Java寫(xiě)一個(gè)冒泡排序算法
3.描述一下鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)。
4.如何遍歷一棵二叉樹(shù)?
5.倒排一個(gè)LinkedList。
6.用Java寫(xiě)一個(gè)遞歸遍歷目錄下面的所有文件。
二、Java基礎(chǔ)
1.接口與抽象類(lèi)的區(qū)別?
2.Java中的異常有哪幾類(lèi)?分別怎么使用?
3.常用的集合類(lèi)有哪些?比如List如何排序?
4.ArrayList和LinkedList內(nèi)部的實(shí)現(xiàn)大致是怎樣的?他們之間的區(qū)別和優(yōu)缺點(diǎn)?
5.內(nèi)存溢出是怎么回事?請(qǐng)舉一個(gè)例子?
6.==和equals的區(qū)別?
7.hashCode方法的作用?
8.NIO是什么?適用于何種場(chǎng)景?
9.HashMap實(shí)現(xiàn)原理,如何保證HashMap的線(xiàn)程安全?
10.JVM內(nèi)存結(jié)構(gòu),為什么需要GC?
11.NIO模型,select/epoll的區(qū)別,多路復(fù)用的原理
12.Java中一個(gè)字符占多少個(gè)字節(jié),擴(kuò)展再問(wèn)int, long, double占多少字節(jié)
13.創(chuàng)建一個(gè)類(lèi)的實(shí)例都有哪些辦法?
14.final/finally/finalize的區(qū)別?
15.Session/Cookie的區(qū)別?
16.String/StringBuffer/StringBuilder的區(qū)別,擴(kuò)展再問(wèn)他們的實(shí)現(xiàn)?
17.Servlet的生命周期?
18.如何用Java分配一段連續(xù)的1G的內(nèi)存空間?需要注意些什么?
19.Java有自己的內(nèi)存回收機(jī)制,但為什么還存在內(nèi)存泄露的問(wèn)題呢?
20.什么是java序列化,如何實(shí)現(xiàn)java序列化?(寫(xiě)一個(gè)實(shí)例)?
21.String s = new String("abc");創(chuàng)建了幾個(gè) String Object?
三、JVM
1.JVM堆的基本結(jié)構(gòu)。
2.JVM的垃圾算法有哪幾種?CMS垃圾回收的基本流程?
3.JVM有哪些常用啟動(dòng)參數(shù)可以調(diào)整,描述幾個(gè)?
4.如何查看JVM的內(nèi)存使用情況?
5.Java程序是否會(huì)內(nèi)存溢出,內(nèi)存泄露情況發(fā)生?舉幾個(gè)例子。
6.你常用的JVM配置和調(diào)優(yōu)參數(shù)都有哪些?分別什么作用?
7.JVM的內(nèi)存結(jié)構(gòu)?
8.常用的GC策略,什么時(shí)候會(huì)觸發(fā)YGC,什么時(shí)候觸發(fā)FGC?
四、多線(xiàn)程/并發(fā)
1.如何創(chuàng)建線(xiàn)程?如何保證線(xiàn)程安全?
2.如何實(shí)現(xiàn)一個(gè)線(xiàn)程安全的數(shù)據(jù)結(jié)構(gòu)
3.如何避免死鎖
4.Volatile關(guān)鍵字的作用?
5.HashMap在多線(xiàn)程環(huán)境下使用需要注意什么?為什么?
6.Java程序中啟動(dòng)一個(gè)線(xiàn)程是用run()還是start()?
7.什么是守護(hù)線(xiàn)程?有什么用?
8.什么是死鎖?如何避免
9.線(xiàn)程和進(jìn)程的差別是什么?
10.Java里面的Threadlocal是怎樣實(shí)現(xiàn)的?
11.ConcurrentHashMap的實(shí)現(xiàn)原理是?
12.sleep和wait區(qū)別
13.notify和notifyAll區(qū)別
14.volatile關(guān)鍵字的作
15.ThreadLocal的作用與實(shí)現(xiàn)
16.兩個(gè)線(xiàn)程如何串行執(zhí)行
17.上下文切換是什么含義
18.可以運(yùn)行時(shí)kill掉一個(gè)線(xiàn)程嗎?
19.什么是條件鎖、讀寫(xiě)鎖、自旋鎖、可重入鎖?
20.線(xiàn)程池ThreadPoolExecutor的實(shí)現(xiàn)原理?
五、Linux使用與問(wèn)題分析排查
1.使用兩種命令創(chuàng)建一個(gè)文件?
2.硬鏈接和軟鏈接的區(qū)別?
3.Linux常用命令有哪些?
4.怎么看一個(gè)Java線(xiàn)程的資源耗用?
5.Load過(guò)高的可能性有哪些?
6./etc/hosts文件什么做用?
7.如何快速的將一個(gè)文本中所有“abc”替換為“xyz”?
8.如何在log文件中搜索找出error的日志?
9.發(fā)現(xiàn)磁盤(pán)空間不夠,如何快速找出占用空間最大的文件?
10.Java服務(wù)端問(wèn)題排查(OOM,CPU高,Load高,類(lèi)沖突)
11.Java常用問(wèn)題排查工具及用法(top, iostat, vmstat, sar, tcpdump, jvisualvm, jmap, jconsole)
12.Thread dump文件如何分析(Runnable,鎖,代碼棧,操作系統(tǒng)線(xiàn)程ID關(guān)聯(lián))
13.如何查看Java應(yīng)用的線(xiàn)程信息?
六、框架使用
1.描述一下Hibernate的三個(gè)狀態(tài)?
2.Spring中Bean的生命周期。
3.SpringMVC或Struts處理請(qǐng)求的流程。
4.Spring AOP解決了什么問(wèn)題?怎么實(shí)現(xiàn)的?
5.Spring事務(wù)的傳播屬性是怎么回事?它會(huì)影響什么?
6.Spring中BeanFactory和FactoryBean有什么區(qū)別?
7.Spring框架中IOC的原理是什么?
8.spring的依賴(lài)注入有哪幾種方式
9.struts工作流程
10.用Spring如何實(shí)現(xiàn)一個(gè)切面?
11.Spring 如何實(shí)現(xiàn)數(shù)據(jù)庫(kù)事務(wù)?
12.Hibernate對(duì)一二級(jí)緩存的使用,Lazy-Load的理解;
13.mybatis如何實(shí)現(xiàn)批量提交?
七、數(shù)據(jù)庫(kù)相關(guān)
1.MySQL InnoDB、Mysaim的特點(diǎn)?
2.樂(lè)觀(guān)鎖和悲觀(guān)鎖的區(qū)別?
3.數(shù)據(jù)庫(kù)隔離級(jí)別是什么?有什么作用?
4.MySQL主備同步的基本原理。
5.select * from table t where size > 10 group by size order by size的sql語(yǔ)句執(zhí)行順序?
6.如何優(yōu)化數(shù)據(jù)庫(kù)性能(索引、分庫(kù)分表、批量操作、分頁(yè)算法、升級(jí)硬盤(pán)SSD、業(yè)務(wù)優(yōu)化、主從部署)
7.SQL什么情況下不會(huì)使用索引(不包含,不等于,函數(shù))
8.一般在什么字段上建索引(過(guò)濾數(shù)據(jù)最多的字段)
9.如何從一張表中查出name字段不包含“XYZ”的所有行?
10.MySQL,B+索引實(shí)現(xiàn),行鎖實(shí)現(xiàn),SQL優(yōu)化
11.Redis,RDB和AOF,如何做高可用、集群
12.如何解決高并發(fā)減庫(kù)存問(wèn)題
13.mysql存儲(chǔ)引擎中索引的實(shí)現(xiàn)機(jī)制;
14.數(shù)據(jù)庫(kù)事務(wù)的幾種粒度;
15.行鎖,表鎖;樂(lè)觀(guān)鎖,悲觀(guān)鎖
八、網(wǎng)絡(luò)協(xié)議和網(wǎng)絡(luò)編程
1.TCP建立連接的過(guò)程。
2.TCP斷開(kāi)連接的過(guò)程。
3.瀏覽器發(fā)生302跳轉(zhuǎn)背后的邏輯?
4.HTTP協(xié)議的交互流程。HTTP和HTTPS的差異,SSL的交互流程?
5.Rest和Http什么關(guān)系? 大家都說(shuō)Rest很輕量,你對(duì)Rest風(fēng)格如何理解?
6.TCP的滑動(dòng)窗口協(xié)議有什么用?講講原理。
7.HTTP協(xié)議都有哪些方法?
8.交換機(jī)和路由器的區(qū)別?
9.Socket交互的基本流程?
10.http協(xié)議(報(bào)文結(jié)構(gòu),斷點(diǎn)續(xù)傳,多線(xiàn)程下載,什么是長(zhǎng)連接)
11.tcp協(xié)議(建連過(guò)程,慢啟動(dòng),滑動(dòng)窗口,七層模型)
12.webservice協(xié)議(wsdl/soap格式,與rest協(xié)議的區(qū)別)
13.NIO的好處,Netty線(xiàn)程模型,什么是零拷貝
九、Redis等緩存系統(tǒng)/中間件/NoSQL/一致性Hash等
1.列舉一個(gè)常用的Redis客戶(hù)端的并發(fā)模型。
2.HBase如何實(shí)現(xiàn)模糊查詢(xún)?
3.列舉一個(gè)常用的消息中間件,如果消息要保序如何實(shí)現(xiàn)?
4.如何實(shí)現(xiàn)一個(gè)Hashtable?你的設(shè)計(jì)如何考慮Hash沖突?如何優(yōu)化?
5.分布式緩存,一致性hash
6.LRU算法,slab分配,如何減少內(nèi)存碎片
7.如何解決緩存單機(jī)熱點(diǎn)問(wèn)題
8.什么是布隆過(guò)濾器,其實(shí)現(xiàn)原理是? False positive指的是?
9.memcache與redis的區(qū)別
10.zookeeper有什么功能,選舉算法如何進(jìn)行
11.map/reduce過(guò)程,如何用map/reduce實(shí)現(xiàn)兩個(gè)數(shù)據(jù)源的聯(lián)合統(tǒng)計(jì)
十、設(shè)計(jì)模式與重構(gòu)
1.你能舉例幾個(gè)常見(jiàn)的設(shè)計(jì)模式
2.你在設(shè)計(jì)一個(gè)工廠(chǎng)的包的時(shí)候會(huì)遵循哪些原則?
3.你能列舉一個(gè)使用了Visitor/Decorator模式的開(kāi)源項(xiàng)目/庫(kù)嗎?
4.你在編碼時(shí)最常用的設(shè)計(jì)模式有哪些?在什么場(chǎng)景下用?
5.如何實(shí)現(xiàn)一個(gè)單例?
6.代理模式(動(dòng)態(tài)代理)
7.單例模式(懶漢模式,并發(fā)初始化如何解決,volatile與lock的使用)
8.JDK源碼里面都有些什么讓你印象深刻的設(shè)計(jì)模式使用,舉例看看?
總結(jié)
以上是生活随笔為你收集整理的java webservice报文过长_工作1-5年的Java程序猿到底需要怎样的一个技术栈?的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: python如何安装torch_PyTo
- 下一篇: python3编码转换_Python3编