外包開始起來了???

      網友投稿 765 2022-05-29

      Hey guys ,這里是 cxuan ,前段時間有位小伙伴跟我分享了他面試外包的經歷,外包也開始卷起來了!!

      最開始是打算面試外包公司刷經驗,等經驗差不多了,再去甲方嘗試,可惜不太順利。

      一、邁思(面試了30分鐘)

      自我介紹

      左連接(a 表左連接 b 表,a 表全部數據出來,b 表沒有的數據為空)

      a 表左連接 b 表,b 表左連接 c 表,c 表左連接 a 表,這樣的數據是什么數據(博主當時有點懵,回答全連接,全部數據會出來。。。)

      sql:一個班的學生有兩個字段,一個字段叫分數,另外一個字段叫組名,有 4 個組,查出每個組的第一名,sql 怎么寫

      select group_name,max(score) from table group by group_name order by group_name

      5.數據庫引擎有哪些(myIsam,InnoDB 等等)

      myIsam 和 Inno DB的區別(InnoDB 支持事務,外鍵,崩潰后恢復,InnoDB 行級鎖,myIsam 表級鎖)

      myIsam 的優點(博主當時只記住了 InnoDB 的優點,沒想到面試官問到了 myIsam 的優點,速度快,磁盤空間占用少)

      Spring 的兩個特性(IOC 和 aop,這兩個特性用到了哪些設計模式)

      java 的容器,集合(老生常談了,list, set, map 等等,另外說一下有哪些實現類)

      hashmap 的實現(數組+鏈表+紅黑樹)

      put 一個 key 和 value,怎么確定數組的下標,如果有兩個key put到同個位置,怎么做?(根據key計算hash值,根據hash確定下標等等)

      HashMap 是線程安全的嗎?有哪些實現?(不是,線程安全的可以用hashtable,concurrentHashMap等等)

      concurrentHashMap 是怎么實現線程安全的?具體的實現?兩個線程同時 put 兩個 key 是怎么做的?

      (1.7數組+鏈表,分段鎖,1.8數組+鏈表+紅黑樹,cas+synchronized)

      java 集合的排序(stream 中的 sort),內部是怎么實現的?原理是什么?了解過哪些排序?

      (Comparable和Comparator 參考鏈接)

      java 集合的分組(groupingby (對象::屬性))

      函數式方法(接口),什么條件下才能用?這種適用于所有的嗎?還是說有一定的限制?

      后臺的請求比較慢,一般是什么原因造成的?后臺請求直接卡了,怎么排查,日志沒報錯呢?(查一下慢sql,需要大量運算)

      怎么查鎖日志,線程日志?(這個不知道)

      常見線程池,這些都是什么樣的線程池?(newCachedThreadPool,newFixedThreadPool,newScheduledThreadPool,newSingleThreadExecutor,現在有6種線程池了,沒記那么多)

      java 鎖,并簡單說一下鎖,類名,關鍵字,鎖的實現等等(ReentrantLock,迷迷糊糊說了一些,畢竟記得不多)

      谷歌 guava 緩存用過嗎?(沒用過)

      項目有哪些難的實現,你是怎么做的?(根據自己的情況去回答)

      二、親鄰科技(甲方)

      過去面試的時候,是星期五晚上8點多了

      一面:hr(不到10分鐘)

      簡單自我介紹,對技術,薪資有要求什么的,跳槽原因,評價自己,公司加班挺多的,問能不能接受

      二面:技術(不到20分鐘,答的有點差)

      對稱加密和非對稱加密的區別

      跨域腳本攻擊(還有好幾個沒聽過)

      數據庫隔離級別(讀未提交,讀已提交,可重復讀,串行化)

      不可重復讀和幻讀是什么?(a重復讀同個數據,b修改數據,a再次讀,就是不可重復讀;a修改某些數據,b從中插入一條數據,a會發現還有一條數據沒修改,那么就是幻讀)

      死鎖是什么?產生原因?怎么解決(競爭同一資源,四個條件,破壞四個條件,這一塊沒答好)

      服務器 cpu 百分百,怎么排查(ps 查看進程,答的不是很好,畢竟這方面沒研究。雖然公司也遇到了 cpu 百分百的情況,但是解決辦法是把需要大量運算的 mrp 功能給禁掉,后面加內存,加服務器。這一塊我可不敢實話實說)

      nginx 可以用來做什么(負載均衡,反向代理,面試官還繼續問還有呢,我不知道什么了,我說可以攔截 ip 等等)

      cas 是什么?(樂觀鎖的一種實現,會造成aba問題,加版本號或者時間戳)

      redis 持久化機制,rdb 和 aof 的優缺點(全量數據備份,安全性低,備份間隔時間長;增量數據備份,數據安全,文件大)

      spring 異步注解(沒用過)

      講一講類加載機制

      內存泄露和內存溢出的區別

      還問了其他一些題目,不太記得了

      講一講項目,你是怎么做的

      三、奧薩醫藥(甲方,面試了35分鐘左右)

      看到一個小姐姐,問路,好漂亮

      進去之后,填資料,填完資料,就問問題

      mysql 的常用引擎,區別(InnoDB:支持事務,外鍵,行鎖,支持崩潰后恢復,面試官還問為什么能恢復。Myisam: 表鎖,全文索引)

      sql 有哪些優化,常用索引(查詢哪些字段,不要用*, null, like后面的"% 等等)

      sql 語句執行的過程是怎么樣的?怎么分析 explain

      假如有 100w 數據,我想要第 60 萬行之后的數據,怎么優化(用limit,加索引,面試官太變態了,問加了這些還很慢,怎么辦)

      redis 是什么,為什么比 mongodb 熱門?(非關系型數據庫,基于內存等等,為什么熱門,這個我就說不知道了,因為不知道 mongodb)

      什么是非關系型數據庫,與關系型數據庫的區別?(沒回答好)

      除了基于內存,讀取速度快,還有哪些原因讓 redis 快?(沒回答好)

      常用的數據類型,應用場景(String,List,Set,Zset,Hash,面試官還問為什么,額,簡直是抽絲剝繭呢)

      持久化機制,rdb 和 aof 的區別,你會怎么選擇哪種機制(全量和增量,備份時間長短,數據安全等等,現在有混合機制)

      淘汰策略有哪些(答到過期策略那里去了,面試官提醒了)

      redis 為什么可以對 String 進行自增自減運算(這個不知道)

      redis 怎么進行優化?(不知道)

      java 常用的集合有哪些?(list,set,map,實現類)

      arrayList 和 linkedList 的區別(數據結構,讀取和增刪速度,線程安全copyonwriteArrayList)

      我想要插入幾十萬數據到 arrayList,有什么優化方法?(這個還真的不知道了)

      hashmap 底層結構,put的過程?為什么要加紅黑數?結構全部用紅黑樹可以嗎?(數組+鏈表+紅黑樹,根據 key 計算 hash,根據 hash 計算下標,下標為 null 就賦值,不為 null,就遍歷判斷 hashcode 相等等等,1.7用頭插,1.8用尾插,加紅黑樹是穩定,效率。數組查詢時間復雜度o(1),鏈表增刪時間復制度o(1),紅黑樹o(log n),效率沒有前面兩者高,所以,不能全部用紅黑樹)

      concurrenthashmap 的結構(1.7分段鎖,1.8cas+synchronize)

      synchronized和 lock 的區別

      hashtable 和 concurrenthashmap 的區別(結構不同,hashtable是鎖整個對象和方法)

      有哪些 java 的鎖?實現類?cas 是什么?aqs 是什么?(樂觀悲觀,公平非公平,只說了 ReentrantLock,面試官接著問還有呢?cas,樂觀鎖的實現,會造成 aba 問題,加版本號或者時間戳。aqs 是鎖框架)

      線程池怎么使用,常用的參數?(使用 ThreadPoolExcutor,核心線程數,最大線程數,時間,隊列,線程工廠,拒絕策略)

      假如有 50 個任務去執行,5 個核心線程,10 個最大線程數,10 個任務隊列,流程是怎么樣的,狀態是怎么樣的?多余的任務是怎么用拒絕策略的(創建 5 個核心線程,10 個放隊列,隊列滿了,再創建 10 個非核心線程,剩余 25 個根據拒絕策略來決定,默認報異常,其余三種:要么忽略,要么放棄最早的線程,要么用該線程去執行)(后來才知道回答錯了,10 個最大線程數,5個核心 + 5個非核心,剩下的 30 個走拒絕策略)

      面試官給我的評價:面試的都能答出來,這一點很不錯,但了解的不深,雖然工作上用不到,但是面試就是這樣造火箭的。面試不會差,但也不優秀,處于待定狀態。

      四、金蝶軟件(甲方,面試了40分鐘)

      問的項目問題比較多,怎么設計功能的,數據庫是怎么設計的

      左連接,右連接,內連接的區別

      mysql 執行計劃,有哪些看的

      springmvc 執行過程,從前端到后臺,再返回前端的過程

      權限驗證,驗權怎么做

      數據庫的鎖(樂觀鎖,悲觀鎖,獨占鎖,共享鎖)

      select, update, delete 對應哪些鎖

      java 集合體系(list,set,map)

      arraylist 刪除元素有哪些注意的地方

      arraylist 是線程安全的嗎(不是,線程安全:vector,copyonwritearraylist)

      什么時候用 arraylist,linkedList(頻繁增刪用 linkedList)

      深拷貝和淺拷貝

      值傳遞和引用傳遞

      多線程,線程池

      資源同步是怎么做的?

      synchronized 可以修飾靜態類嗎

      lock 和 synchronized 的區別?用的話,你會怎么選

      平時怎么學習的(看教程,看博客)

      自己的規劃是什么?(規劃學微服務,分布式等等)

      技術方面的優勢是什么

      代碼怎么優化,重構(單一職責,共用等等)

      自己的網站是怎么進行性能優化的?(加 cdn,加 redis)

      你有什么想問我的?你們那邊用到的技術是什么?面試官:技術桟是封裝框架,沒有前端,用拖拉組件什么的,微服務是 dubbo,數據庫是 oracle,側重點是業務,技術次要。

      最后面試官說:有四輪面試,這邊面試完跟總監商量一下(剩下3輪都不是技術面)

      五、平安銀行(外包,面試了40分鐘,因為有事,最后中斷了)

      spirngboot 啟動原理(內嵌 tomcat…)

      啟動的注解(springbootapplication)

      springboot 核心配置

      外包也開始卷起來了???

      配置文件的方式(yml, properties)

      springmvc 的工作流程

      springmvc 的組件

      @RequestMapping 的作用(攔截 url)

      spring 常用的模塊,核心

      說一說 ioc 和 aop

      spring 常用的注入方式

      spring 的 bean 有沒有了解

      spring 事務的實現

      spring 的隔離

      數據庫的隔離級別(讀未提交,讀已提交,可重復讀,串行化)

      隔離級別的影響(臟讀,不可重復讀,幻讀)

      原子性,持久性(不可分割,保存到數據庫)

      char 和 varchar 的區別(字節大小,’'和"")面試官繼續問還有沒有。。。

      left join 和 right join 的區別

      sql 你是怎么調優的

      sql 執行計劃(explain)

      sql 的行鎖和表鎖,優勢(鎖一行和鎖整個表)

      樂觀鎖,悲觀鎖(版本號,時間戳)

      mysql 的引擎,區別(innodb 支持外鍵,行鎖,支持奔潰恢復,myisam 支持全文索引)

      select count(*) from table,數據是怎么執行的,會造成全表掃描嗎(innodb,不支持全文索引,所以在innodb會造成全表掃描)

      float 和 double 內存占多少字節

      在自增表,有6條數據,刪了兩條數據,再增加一條數據,這條數據的id是多少(innodb是7,myisam是5,結果說反了)

      redis使用場景,和 memcache 的區別

      redis 的持久化(rdb 和 aof,全量,增量)

      了解 redis 分布式,有多少個節點,以及一些命令

      nginx應用場景(前后端分離,負載均衡)

      負載均衡的策略(輪詢,權重等等)

      前后端是怎么交互的

      正向代理和反向代理

      swagger 有了解嗎(接口文檔)

      == 和 equals 的區別

      堆棧有了解嗎

      stringbuilder 和 stringbuffer 的區別(線程安全,效率)

      io 流(reader和writer,inputstream和outputstream)

      fileinputstream 和 bufferinputstream 的區別

      集合(list,set,map)

      線程安全的集合有哪些(vector,copyonwritearraylist,hashtable, concurrenthashmap)

      hashmap的實現過程(1.7頭插,1.8尾插)

      hashset 和 linkedhashset(底層hashmap,有序,底層 linkedhashmap,無序)

      深拷貝,淺拷貝

      問的時間差不多40分鐘了,因為還要工作,就打斷面試了,結果晚上就來了第二輪面試

      平安銀行第二輪面試(面試了26分鐘)

      mysql 查詢,有很多關聯的表,怎么優化(表加字段,適當冗余,少關聯表,不要用*,in,null,or, %等等)

      索引失效的情況(in,null,or, %等等)

      常用的集合類(list,set,map及實現類)

      線程安全的容器有哪些(vector,copyonwritearraylist,hashtable,concurrenthashmap)

      concurrenthashmap 是怎么保證線程安全的(1.7用分段鎖,16個都上鎖,1.8用cas+syn)

      hashmap 的數據結構(1.7數組+鏈表,多線程會形成一個環,cpu會飆升100%,1.8數組+鏈表+紅黑樹)

      什么情況下會轉成紅黑樹(key,hash,數組大于64,鏈表大于8,轉成紅黑樹)

      重寫了 equals,還需要重寫 hashcode 方法嗎(因為根據 key,hash 計算出來有可能會沖突,所以要重寫hashcode)

      鏈表是雙向鏈表嗎

      redis的數據結構(string,set,sort set,list,hash,bitmap等等)

      redis 分布式鎖

      b+ 樹了解嗎(mysql索引)

      緩存擊穿(緩存失效,在緩存找不到,在數據庫有數據)

      解決辦法(設置緩存失效時間隨機,錯開時間,或者給個標記)(其實是設置熱點數據永遠不過期或者加互斥鎖等等)

      threadlocal有了解嗎(發音沒聽清,聽成什么logo了,聽了三遍沒聽出來,后面才反應他要說什么)

      項目中遇到的困難(mrp功能)

      服務器 cpu 上升到90以上的時候,還可以用多線程嗎?

      最近有研究什么新的技術嗎?(在學習微服務)

      微服務相關組件,一些沒聽過(說了一下這些是干嘛的)

      zookeeper有了解嗎(分布式)

      內存泄露有哪些情況?

      從專業角度+性格,評價自己

      你希望的項目是什么樣的?(技術桟,技術氛圍)

      linux常用命令(ls,cd,pwd,chmod,vi,whereis,find二進制文件)

      面試官:到崗時間比較急,技術棧是 springboot+dubbo,微服務集群,zookeeper+redis+mysql 等等

      面試評價:沒什么大問題,希望快點入職

      結尾

      jvm,微服務和分布式等等的沒有記錄了,自己沒接觸過,聽到了也忘記,沒有及時寫上去。還有一些面試,沒有去記錄了,整理和記錄面試挺費時間的,上面的主要記錄技術面試。有些終面,面了 40 分鐘,問生活細節,有什么愛好,之前寫的博客,還記得嗎?xx篇,你還記得寫了什么內容嗎?你是哪里人,將來是不是還待在深圳?暈死,一直問,問了 40 多分鐘,如果我不打斷,可能會一個小時以上。像這樣的流水賬面試,就沒有寫到上面去了。

      最后比較幸運,拿下幾個 offer,面試題還是得多刷題,避免答不出來,另外收到offer的機會才會多。

      總結

      待的公司,比較安逸穩定,也算是個溫室,業務比較復雜(ERP 系統),項目架構比較簡單,單體項目,去年說加緩存的一直沒加,單表數據最多是上千,現在是 260 多張表。目前有 20 個客戶,cpu 飄升到百分之 90,之后,服務器奔潰,好幾次都這樣。后來我們 CTO 的解決辦法是把功能給禁掉(MRP 運算),后來發現是報表問題,oom 錯誤,換了報表工具。過了一段時間,加了內存,加服務器。(微服務,分布式,緩存,集群,消息隊列都沒用到,也學不到),一直做一些復雜的業務功能,寫業務代碼。還是早一點離開技術得不到提升的地方,雖然他一直給我洗腦,說會那么多技術有什么用,你業務不會,代碼不會寫,會再多技術也是等于零。但我心里一直否認,畢竟我是搞技術的,懂基本業務可以,討論業務,需求可以交給項目經理什么的,最后安排我做什么就行了。除非走業務路線,走管理,懂技術懂業務。像我這種學五渣,不適合走業務。

      這些面試題的答案很多都在我寫的六本 PDF 中了,獲取鏈接如下

      免費領取六本 PDF

      另外,如果這篇文章對你有幫助的話,希望你給我點個贊哦!!!

      任務調度 數據庫

      版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。

      上一篇:【王喆-推薦系統】模型篇-(task9)強化學習推薦模型DRN
      下一篇:陳曄:測試平臺化是趨勢,但不應強求
      相關文章
      亚洲一区二区三区在线观看网站 | 亚洲AV无码一区二区三区牲色| 亚洲成人在线电影| 亚洲乱码一区二区三区在线观看| 亚洲国产一区视频| 亚洲av成人一区二区三区在线观看 | 亚洲成a人片在线网站| 91情国产l精品国产亚洲区| 亚洲综合一区二区精品导航| 久久精品视频亚洲| 亚洲图片一区二区| 亚洲欧洲日产国码www| 亚洲成人黄色在线| 亚洲va在线va天堂成人| 国产精品亚洲精品观看不卡| 亚洲第一男人天堂| 亚洲爆乳成av人在线视菜奈实| 亚洲国产aⅴ成人精品无吗| 亚洲heyzo专区无码综合| 在线观看亚洲电影| 国产亚洲精品影视在线产品| 亚洲综合网站色欲色欲| 亚洲国产综合无码一区| 亚洲国产精品久久久久婷婷老年 | 怡红院亚洲红怡院在线观看| 老子影院午夜伦不卡亚洲| 国产综合成人亚洲区| 国产亚洲成人久久| 亚洲AV无码乱码在线观看富二代| 亚洲精品自产拍在线观看动漫| 亚洲高清日韩精品第一区 | 国产亚洲精品激情都市| 国产AV无码专区亚洲Av| 亚洲三级电影网站| 亚洲一级毛片在线播放| 亚洲精品成a人在线观看☆| 亚洲人成无码网WWW| 亚洲国产精品无码专区影院| 99人中文字幕亚洲区| 亚洲婷婷第一狠人综合精品| 久久久久亚洲精品无码网址色欲 |