主頁 > 軟體設計 > Java崗四面位元組跳動成功之前,我都刷了那些面試題以及做了那些準備!

Java崗四面位元組跳動成功之前,我都刷了那些面試題以及做了那些準備!

2020-11-15 14:07:48 軟體設計

一面

一面面試老師是個小姑娘,人特別好(不僅僅指長相啊),

問了mysql的索引

Redis的string型別

為什么使用rabbitmq

rabbitmq有哪些部件,如何保證準確性跟一致性,

演算法問了兩道

快排

無序陣列計算每個位置大于前面的多少個數字(歸并排序)

二面

二面就開始偏向專案了,

如何進行jvm調優(然后我巴拉巴拉,老師說你寫下具體的引數跟請求命令)

cpu滿了重啟系統后好了,但是一會又滿了,如何具體解決,(老師有點嚴格,一直說我不要聽原理,你給我說具體的命令)

然后問了如何設定秒殺系統

如何設定銀行系統,會碰到什么問題

為什么專案中使用了mongodb

同樣兩個演算法

一個文本距離計算

(用動態規劃解決)

一個是無序陣列可以存盤多少雨水問題

三面

沒有問技術

就是聊了聊怎么學習的

看了那些書

如何設定一個搶紅包的功能

以及自己專案中碰到了哪些問題,如何解決的

專案的技術選型以及為什么要選擇它

然后最手寫一個演算法

實作對hashmap增強,加上過期自動洗掉還有淘汰策略實作最短過期時間洗掉

HR面

技術規劃

還投了哪些公司

位元組了解

為什么考研

專案中最大的識訓

這里是我四面位元組成功之前,刷過的面試題;分享給大家!沒有包括演算法,因為演算法系列的比較多,但是我整理了PDF,需要的話可以“加我VX小助理”來免費獲取到!

Java基礎

  • JAVA 中的幾種資料型別是什么,各自占用多少位元組,
  • String 類能被繼承嗎,為什么,
  • 兩個物件的 hashCode() 相同,則 equals() 也一定為 true,對嗎?
  • String 屬于基礎的資料型別嗎?
  • Java 中操作字串都有哪些類?它們之間有什么區別?
  • Java 中 IO 流分為幾種?
  • BIO、NIO、AIO 有什么區別?
  • 用過哪些 Map 類,都有什么區別,HashMap 時執行緒安全的嗎,并發下使用的 Map 是什么,他們的內部原理分別是什么,比如存盤方法,hashcode,擴容,默認容量等,
  • 如何將字串反轉?
  • 抽象類必須要有抽象方法嗎?
  • 普通類和抽象類有哪些區別?
  • 抽象類能使用 final 修飾嗎?
  • ArrayList 和 LinkedList 有什么區別?
  • ConcurrentHashMap的資料結構(必考)
  • volatile作用(必考)
  • Atomic類如何保證原子性(CAS操作)(必考)
  • 為什么要使用執行緒池(必考)

Redis

  • Redis的應用場景
  • Redis支持的資料型別(必考)
  • zset跳表的資料結構(必考)
  • Redis的資料過期策略(必考)
  • Redis的LRU過期策略的具體實作
  • 如何解決Redis快取雪崩,快取穿透問題
  • Redis的持久化機制(必考)
  • Redis為什么是單執行緒的?
  • 什么是快取穿透?怎么解決?
  • Redis持久化有幾種方式?
  • Redis為什么這么快?(必考)
  • Redis怎么實作分布式鎖?
  • Redis如何做記憶體優化?
  • Redis淘汰策略有哪些?
  • Redis常見的性能問題有哪些?該如何解決?
  • Redis的使用要注意什么?

ZooKeeper

  • CAP定理
  • ZAB協議
  • leader選舉演算法和流程
  • zookeeper 是什么?
  • zookeeper 有幾種部署模式?
  • zookeeper 怎么保證主從節點的狀態同步?

Mysql

  • 事務的基本要素
  • 事務隔離級別(必考)
  • 如何解決事務的并發問題(臟讀,幻讀)(必考)
  • MVCC多版本并發控制(必考)
  • binlog,redolog,undolog都是什么,起什么作用
  • InnoDB的行鎖/表鎖
  • myisam和innodb的區別,什么時候選擇myisam
  • 為什么選擇B+樹作為索引結構(必考)
  • 索引B+樹的葉子節點都可以存哪些東西(必考)
  • 查詢在什么時候不走(預期中的)索引(必考)
  • sql如何優化
  • explain是如何決議sql的
  • order by原理

JVM

  • 運行時資料區域(記憶體模型)(必考)
  • 垃圾回識訓制(必考)
  • 垃圾回收演算法(必考)
  • Minor GC和Full GC觸發條件
  • GC中Stop the world(STW)
  • 各垃圾回收器的特點及區別
  • 雙親委派模型
  • JDBC和雙親委派模型關系
  • JVM 中一次完整的 GC 流程是什么樣子的,物件如何晉升到老年代,說說你知道的幾種主要的 JVM 引數

Spring

  • Spring的IOC/AOP的實作(必考)
  • 動態代理的實作方式(必考)
  • Spring如何解決回圈依賴(三級快取)(必考)
  • Spring的后置處理器
  • Spring的@Transactional如何實作的(必考)
  • Spring的事務傳播級別
  • BeanFactory和ApplicationContext的聯系和區別

其他

  • 高并發系統的限流如何實作
  • 高并發秒殺系統的設計
  • 負載均衡如何設計

作業系統篇

  • 行程和執行緒的區別
  • 行程同步的幾種方式
  • 執行緒間同步的方式
  • 什么是緩沖區溢位,有什么危害,其原因是什么
  • 行程中有哪幾種狀態
  • 分頁和分段有什么區別

多執行緒篇

  • 多執行緒的幾種實作方式,什么是執行緒安全
  • volatile 的原理,作用,能代替鎖嗎?
  • sleep 和 wait 的區別
  • sleep(0)的意義
  • Lock 和 Synchronized 的區別
  • synchronized 的原理是什么,一般用在什么地方(比如加載靜態方法和非靜態方法的區別)

補充

另外還會考一些計算機網路之類的,像訊息佇列,RPC框架這種考的比較少,計算機網路就是分層啊,tcp/udp啊,三次握手之類的,作業系統就是行程與執行緒啊,行程的資料結構以及如何通信之類的,

資料結構的排序演算法也比較常考,考的話一定會讓你手寫個快排,剩下的演算法題就靠LeetCode的積累了,其實非演算法崗考的演算法題都蠻簡單的,很多題完全就是考察你智力是否正常,稍微難點的涉及到一些演算法思想的按照LeetCode題目型別的分類,每種題做一兩道基本就能完全應付面試了,

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/217459.html

標籤:其他

上一篇:停車場系統

下一篇:話說軟體行業它的路在何方?

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more