<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          入職微軟一個月感悟

          共 3934字,需瀏覽 8分鐘

           ·

          2021-04-29 21:38

          本文是云峰入職微軟一月后的感悟,談及了他的面經(jīng)以及入職體驗。

          前言

          提到微軟,你首先會想到什么?外企?Windows Or Office?還是 955·WLB?

          我在前司待了快三年,自覺到了一個打工人的黃金跳槽點,于是就想出去試試不一樣的工作環(huán)境。

          前司是一個典型的互聯(lián)網(wǎng)公司,提倡短平快的工作節(jié)奏。彼時的我,負(fù)責(zé)一個不大不小的項目,卻遇到瓶頸,怎么也做不大。在我面前有兩個選擇:吃老本 or 跳槽。

          我選擇后者,因為在一個人分飾多角的項目中,我察覺到了我的能力短板:不夠?qū)I(yè)。這又導(dǎo)致了我想好好做成一件事的話必須加班來完成(開會、溝通用戶、梳理需求、設(shè)計項目架構(gòu)、編寫代碼、測試、上線和運維、技術(shù)支持和 oncall),而這又讓我失去了業(yè)余時間去提升我的能力短板,最后的結(jié)果往往達不到專業(yè)的水準(zhǔn),從而繼續(xù)惡性循環(huán)。

          在環(huán)顧了一圈市場上的企業(yè)后,我選擇嘗試微軟,因為在我看來,它有至少以下三點我非常渴望擁有的東西:

          1. 全英文環(huán)境,鍛煉英語技能

          2. 坐擁多個大型項目,可以學(xué)習(xí)到專業(yè)的項目開發(fā)流程

          3. 可以體驗 wlb 的工作節(jié)奏

          面試

          在某一天,我在某 App 上被一個微軟的陌生人勾搭,簡單地電面后一拍即合,我向他投遞了簡歷。

          正式的面試一共有四輪,三輪技術(shù)面 + 一輪 AA 面(大老板),每輪持續(xù)時間一個小時左右。

          除了最后一面聊了聊人生、理想、邏輯推理等非技術(shù)內(nèi)容。其他三面基本上是項目算法各半小時。

          算法

          算法基本落在 leetcode 前兩百道題非 hard 范圍內(nèi),有個別題在原題的基礎(chǔ)上進行了變式。(我被考察的是數(shù)組、樹、圖、遞歸類型的題目)

          與某些公司對算法題的考察不同,我的面試面板沒有 AC 要求,換句話說就是白板編程,面試官提供的只是一個空白的在線編輯器。

          他們似乎更注重和你的溝通而不是僅僅得到答案,每一輪算法部分我都是先向面試官確認(rèn)測試用例的形態(tài),也就是輸入什么得到什么輸出。然后才開始做,做的過程中面試官會提醒你,然后如果做快了,面試官會添加限定條件,將這個題的難度提升一些(類似 leetcode TwoSum -> ThreeSum)。

          項目

          項目基本上就是我將自己簡歷上的項目背景以及實現(xiàn)亮點介紹清楚后,他們從他們的視角進行提問,比如為什么使用 XX 技術(shù)方案?權(quán)衡的原因?如何衡量哪個方案好?怎么用數(shù)據(jù)驅(qū)動項目做的更好?

          最后一般就引出類似系統(tǒng)設(shè)計的問題,比如如何設(shè)計一個組件庫、設(shè)計一個狀態(tài)管理層、設(shè)計一整個應(yīng)用(比如 office online 版本)。

          看到這的讀者可能也明白了,這個團隊是偏前端的,所以沒有問太多關(guān)于后端的東西。當(dāng)然,換個團隊面可能就不是這樣了。

          英語

          因為我面試前說明了自己英語不太好,所以面試全部采用中文進行。

          其他

          面試完成后第二天我就收到了通過的通知,接著就是發(fā) Offer,接受背調(diào),約定入職。薪資方面總包大概降了 30% 左右,這主要看個人取舍了。

          會議

          入職后我第一個想說的部分就是關(guān)于會議。前司我每周的必參加會議只有一個,那就是小組周會,時長也就半小時。其他會議都是按需加載。

          但在這,每周有 8-9 個小時必參加會議(5 - 6個),如果按標(biāo)準(zhǔn)工時一周 40 小時計算的話,每周 20% 以上時間都在開會。如果可選的會議多的話,每周占到 35% - 50% 也不是不可能的(比如我的 manager)。

          如果僅僅是參加會議倒也還好,對我來說最有挑戰(zhàn)的是,它們幾乎是全英文的(除了我和 manager 的 1:1),而且我還必須要發(fā)言。

          英語

          這場面有點出乎我的意料了,我原以為只是郵件等書面材料需要用英文,沒想到除了口頭溝通(僅限中國同事)之外全部采用英語形式。

          有的同事說的很快,有的口音千奇百怪。每天我到公司上班,就好像出國了一樣。

          針對這種情況,除了制定學(xué)習(xí)計劃并執(zhí)行下去,好像沒什么好辦法。

          對于我這種典型的 “啞巴英語” 用戶而言,

          讀的優(yōu)先級最低,因為可以隨時用工具翻譯(瀏覽器的劃詞插件,office 的翻譯工具等)。

          寫其次,主要要考慮單詞量和語法,這個可以用機器翻譯 + ai改作文(語法、詞語替換等,如 grammarly、微軟愛寫作)解決。

          而且讀寫是異步的,用工具后效率大大提高,但聽說是實時的,是工作中最可能成為阻礙的部分。

          目前聽的話我每天抽出 1-2 小時來聽寫了,找自己感興趣的美劇、播客等先 0.75 倍速聽寫,然后對照字幕標(biāo)出錯誤的地方,然后換正常倍數(shù)聽,再換到 1.25 倍。

          說的話報了某 APP 上的一個班,每天通過課程練習(xí)半小時左右。每周再抽空去參加英語角和類似水平的中國同學(xué)用英語交流一個小時。

          做了以上學(xué)習(xí)計劃后,每次開會輪到自己發(fā)言,還得提前打草稿,只要不遇到復(fù)雜問答的問答環(huán)節(jié),基本可以應(yīng)付了。

          目前的英語水平評測結(jié)果:

          希望半年后可以全面達到 C1 level~

          如果讀者有什么更好的英語學(xué)習(xí)方法,歡迎和我一起交流~

          coding

          由于我目前還在新人 (ramp up )階段,所以沒有分很大的活給我。

          不過小需求,在這里不一定代表著簡單。

          看似增刪改查傳參數(shù)的邏輯,代碼不足百行。

          但其實 code review 的時候就被吊打,反反復(fù)復(fù)刪改代碼幾十遍,才合入了主分支。

          一部分是因為代碼不夠優(yōu)雅,沒有遵守最佳實踐(比如函數(shù)設(shè)計、變量命名、注釋、排版)。

          另一部分其實是因為實現(xiàn)方案的權(quán)衡,如果有更好的方案(性能更優(yōu),成本更低,風(fēng)險更低)就需要重構(gòu)來達到。而這部分其實需要大量 coding 之外的工作。

          非 coding

          可以說一個需求的上線里,coding 其實只占用了 10% 的時間。

          40% 的時間用來溝通:在微軟,想一個人做成某件事是非常難的。從提交代碼時,就有技術(shù)同事幫你把關(guān),到上測試環(huán)境和產(chǎn)品、qa 溝通,再到部署。特別是依賴別人的項目或者產(chǎn)品基礎(chǔ)上做事情時。

          1. 郵件溝通,郵件溝通在微軟起到了一個非常重要的環(huán)節(jié)。因為大家可能在不同的時區(qū)工作,所以異步且正式的郵件方式成了官方推薦的溝通環(huán)節(jié)。這樣的好處就是每個人都可以按照自己的節(jié)奏安排工作。
          2. IM 或口頭溝通,這種屬于非正式溝通,比較高效,但是基本定不下結(jié)論。而且 Teams 經(jīng)常出 bug,大家稍微正式點的溝通還是用郵件,和前司 IM 為主的模式不同,這里的 IM 看起來是輔助郵件而存在的。
          3. 會議溝通,這種一般是針對特定的議程得到特定的結(jié)果。有的是工程師們針對技術(shù)方案的討論,有的是工程師、pm、設(shè)計師對項目和產(chǎn)品的討論。還有的是跨團隊溝通。
          4. code review 溝通,這種就是提交代碼后全組的同事來挑你代碼的毛病了,幾十行代碼得到幾十條 comments 是常事,有時候因為大佬的一個 comment 推翻重寫也是常有的事。

          20% 的時間用來設(shè)計:

          1. 做的事影響的范圍。如果影響范圍較大需要拉相關(guān)的同事一起來討論。
          2. 可維護性,有的技術(shù)方案雖然可以解決問題,但是可能會對提高同事后續(xù)的維護成本。(所以要應(yīng)用各種設(shè)計模式的時候很容易被人說過度設(shè)計)
          3. 性能。包大小、應(yīng)用加載速度、服務(wù)穩(wěn)定性等都是被考量的因素。畢竟這些可以被量化。
          4. 安全,此處細(xì)節(jié)略過。
          5. 用戶隱私,此處細(xì)節(jié)略過。
          6. 可訪問性,微軟還是很重視殘障用戶的需求的,對于視障聽障或者運動障礙等的用戶也照顧到。
          7. 兼容 IE...

          20% 的時間用來測試:

          1. 自測,自己測功能看是否達到預(yù)期
          2. 內(nèi)測,組內(nèi)同事幫忙測功能是否達到預(yù)期,以及一些邊界情況。這需要單獨組織個會議。
          3. 單測。主要集中在數(shù)據(jù)處理和 ui 組件上。
          4. e2e 測試,還沒接觸到,但有人在維護。你提交的代碼一定要通過這些用例。

          10% 的時間用來總結(jié)和分享:在會議上總結(jié)自己的工作,同步給參與的同事。如果這段經(jīng)驗復(fù)用價值比較高的話,還需要做 PPT,舉辦一場分享。

          一個例子

          一個 sdk 升級引來的慘案。

          我接到一個活,是修一個 bug ,但它其實是第三方庫 A 的問題,然后我引了個另一個第三方庫 B 來修它,不過這樣做會讓整體的代碼 gzip 后大概大了40 k,即使我用了懶加載。然后大佬 code review 評論別用 B 了,直接升級 A,改代碼升完了,告訴 PM,又說很多地方用了 A,我要是升級的話得同步一堆人先討論這個變更是否值得,ROI 高不高。然后又是一通郵件 + 會議,現(xiàn)在還沒個定論...

          wlb

          整體公司大環(huán)境還是慢的,提倡 wlb,排期也不會特別緊。但是我這個組氛圍比較 push,主動加班的人也多。

          每晚八九點打開 Teams,一定有人在提 pr,再晚一點甚至周末也有同事在干活,估計我過了新人期(這邊叫 ramp up),也不會比前司輕松。

          當(dāng)然,沒有加班費。自愿的。

          manager 的管理風(fēng)格屬于那種 MicroManager,需要進行日常匯報(可能也解釋了為什么會議那么多),現(xiàn)在已經(jīng)哪天不匯報進展和問題就心慌了,每天高(jin)效(zhang)地工作,不存在摸魚。

          如果輪值成 oncall,需要 7x24 待命,那應(yīng)該是最忙的時候,不過要半年后才輪到我。只能期望那時候已經(jīng)熟悉了整個項目和相關(guān)的合作同事了吧。

          總結(jié)

          再回顧一下我最初來微軟所追求的三樣目標(biāo):

          1. 鍛煉英語技能 ?? 但是難度超過預(yù)期了,需要額外付出精力提高

          2. 學(xué)習(xí)到專業(yè)的項目開發(fā)流程 ?? 倒是很享受這個痛苦而又滿足的過程

          3. 體驗 wlb 的工作節(jié)奏 ? 業(yè)余時間用來學(xué)習(xí)英語或者了解項目

          我只想說,微軟其實并沒有想象的那么輕松。

          關(guān)注我們

          我們將為你帶來最前沿的前端資訊。

          瀏覽 43
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  成人欧美18 | 精品免费囯产一区二区三区四区的使用方法 | 日韩三级片免费观看 | 91射| 欧美黄色日韩 |