Re: [請益] 面試如果考coding可以這樣回答嗎?

作者: w0005151 (藍廳)   2024-03-03 15:20:26
一些想法隨筆寫寫,沒什麼組織還請見諒
1. 程式碼品質要能轉化出可以量化的指標
比如我這個feature多花一個禮拜可以用更有效率的方法存取資料讓cost降低50%
或issue發生的頻率降低30%減少工程師加班成本
剛開始工作吵吵clean cod什麼的沒關係
但不要五六年經驗還整天說這段code不乾淨我要爆改你不要質疑我,問就是你不懂
這樣不僅沒用又很像巨嬰
2. 要做什麼事先想想公司規模
大公司制度成熟,你想推新的practice,先想想舊的為什麼可以跑20年
現在有什麼缺陷?真的需要嗎?
小公司發揮空間大但營運壓力也大,可能下個月沒搶到客人公司就要倒了
這時候你還跟老闆說我要refactor這段code
這個月先不要塞新feature給我
沒把你開了就不錯了
3. 不要太糾結老闆懂不懂技術,懂技術的老闆雞巴起來才是最要命的
「這個這麼簡單我10年前一天就做完了你跟我說要一個月?」
「不要騙我沒寫過程式喔,20年前我們都是一個人做一個網站的哪分什麼前後端」
產品性質、公司規模、團隊文化,才是重點
PM也是,好的PM不用很懂技術,而是能好好規劃產品方向,讓大家事半功倍
然後把客人管理好不要一天到晚被情緒勒索
4. 程式技術一直是往越來越人性化的方向走
從早期打孔,組合語言,再到C、Fortran等高階語言
又發展成JS和Python等腳本語言大行其道
everything that can be written in javascript will eventually be written in
javascript
(我個人不是很認同這句話就是了)
再到一行code不用寫就可以搭建ERP系統、電商網站等常見的應用
維運從放機房的實體機,到雲端上的VM,再到由Vendor全面代管的Serverless
要設定的東西越來越少
寫程式的門檻早在AI出現以前就越來越低
但軟體工程師的需求卻沒有變少
以前不會寫可能要去圖書館翻書
後來可以上網估狗或Stackoverflow
Copilot出來後連視窗都不用切了,直接在IDE內一鍵auto complete
只不過是工作型態變了而已
幾十年後寫程式的工作終究會被AI完全取代
只是到那個時候這個社會上目前的工作又會剩下多少呢?
與其說是被取代,我更覺得會是換種工作型態罷了
5.
前陣子剛好看到一篇文章
https://dagster.io/blog/skip-kafka-use-postgres-message-queue
大意是在說工程師不要什麼都想用最適合或最好的技術
引入新技術有很多隱形成本
包含學習成本、監控、評估、維運成本
這些都要列入考量
他舉的例子是他們用PostgreSQL來當message queue,而沒有用Kafka之類的「正統」工具
軟體工程師的工作中,「寫程式」可能是最花時間,但不會是最重要的
這件事隨著年資越來越深會更明顯,如果AI能大幅縮短寫程式的時間,我是樂見其成
代表我們有更多時間去做其他更有價值的事情
作者: steak5566 (牛排56)   2024-03-03 15:35:00
老黃說得對 因為工具升級導致人的生產量大增 會先消失的是那些只會拉excel的
作者: wulouise (在線上!=在電腦前)   2024-03-03 15:50:00
refactor不看商業價值本來就是有問題的
作者: adamkk (愛還記得嗎)   2024-03-03 16:56:00
基本的clean code還是要有,至少要過clang-tidy之類,不然很多安全檢查過不了;當客戶要求安檢的報告時會直接升天
作者: darkMood (瞬間投射)   2024-03-03 17:16:00
嘻嘻
作者: k798976869 (kk)   2024-03-03 18:20:00
美國軟體工程師最喜歡玩一堆新的很潮的東西 玩爽惹之後跳槽跑掉 維運就留給剩下來抓交替的然後不幸被抓到的時候 還是不維護 改成用新東西重做新的
作者: Ericz7000 (Ericz7000nolan)   2024-03-03 19:43:00
我也想玩新東西
作者: chuegou (chuegou)   2024-03-03 21:12:00
阿我現在都看著自己以前的爛code(上個月寫的)然後說很醜要爆改
作者: peter98 (新兵)   2024-03-03 21:12:00
工作吵吵乾淨的鱈魚 0.0
作者: chuegou (chuegou)   2024-03-03 21:14:00
美其名叫重構 但我也提不出任何重構改善的數據指標仔細想想也是滿心虛的
作者: NTUTM04 (TM終號機)   2024-03-03 21:32:00
true
作者: gn60311 (Peterman)   2024-03-03 22:28:00
這篇真的是體會過才寫得出來的qq
作者: IhateOGC (我討厭)   2024-03-03 23:17:00
how to ,and why thatclean code叫他吃屎吧專案剛開始就是寫一陀屎,怎要後面的人clean?說clean code的大概都沒做過大專案linux source code也是一堆屎,也沒人抱怨小公司想搞啥clean?
作者: superpandal   2024-03-03 23:40:00
那叫作為換而換技術 通常也是為了找新工作有新談資的人會去弄的 永遠都在追東追西的人 然後沒有一件是完美符合所有而且這也沒什麼正不正統問題 無宗可溯 滿地都有的應用 都沒什麼歷史與哲理
作者: drajan (EasoN)   2024-03-03 23:56:00
你沒有聽過CV- driven development嗎?玩新技術就是要跳槽用的啊
作者: viper9709 (阿達)   2024-03-04 00:16:00
還滿中肯的
作者: abccbaandy (敏)   2024-03-04 00:54:00
樓樓上那個早就被刷題取代了吧,現在很少問了
作者: saladim (殺拉頂)   2024-03-04 01:29:00
會包function我就謝天謝地了 不需要什麼fancy的技術然後程式邏輯要清楚比較重要 要不然clean code也是屎
作者: holebro (穴弟弟)   2024-03-04 02:21:00
好文
作者: justaID (快樂崇拜)   2024-03-04 07:56:00
這篇語氣很直,但觀點很寫實,職場上還真的看過不少為技術而技術,整天嚷嚷著clean code或一些高大上的技術,缺乏考慮產品實際應用場景、原本這麼寫是為了解決什麼問題、有什麼原因、重構或導入新做法能帶來什麼效益、有什麼side effect風險,履歷驅動開發履歷驅動開發的風格,試圖導入一些看起來很fancy或整天用很溫室的角度空談夢幻中的系統設計職場上遇到這種巨嬰隊友很心累
作者: crowley (蒼蠅拍)   2024-03-04 08:46:00
作者: devilkool (對貓毛過敏的貓控)   2024-03-04 08:58:00
履歷驅動開發XD 這名詞不錯
作者: B0988698088 (廢文少女小円♥)   2024-03-04 10:52:00
這篇叫很直的話建議先檢討自己是不是太玻璃了
作者: v7q4 ((.)(.)乳劍雙修 -|=>)   2024-03-04 12:53:00
我部門就一個整天喊code很髒、要重構啦開會時被質疑bug不解 在那想怎麼重構有什麼特別意思 他就爆氣了! 直接跟另一個人對罵 還講到快哭出來XDD
作者: iamOsaka (歐沙卡)   2024-03-04 13:21:00
推 1真的很實際
作者: shooter555 (shooter)   2024-03-04 13:25:00
clean是指工作期程內自己clean啦 不是叫你拉時間重構
作者: Ericz7000 (Ericz7000nolan)   2024-03-04 14:25:00
重構那本書我記得好像有提到定期要花時間去處理重構
作者: drajan (EasoN)   2024-03-04 19:52:00
別人程式要重構是因為預期未來會添加新業務邏輯進去 有助於提升生產力 你程式要重構是因為你看書之後想照抄 別人有我也要有的概念。別人生小孩是婚姻幸福經濟穩定家庭關係和諧,你生小孩是因為你想照抄但沒注意到背景環境完全不同不過說實在的我剛開始工作時也是這樣的心態,資深幹久了就知道這些招式都是浮雲,能產生什麼經濟效益才是最根本的關鍵
作者: brucetu (sec)   2024-03-04 21:00:00
有時候抱怨code髒看不懂的人只是因為他理解力太差0.0做久了什麼智障義大利麵沒看過,還不是照樣功能疊上去被調到某個案子支援一兩個月的情況,更不用討論重構,趕快弄懂改一改就好
作者: Phenomenon (Kuma)   2024-03-04 22:31:00
很現實,但面試需要演一下 xd
作者: viper9709 (阿達)   2024-03-05 00:04:00
推做久了什麼智障義大利麵沒看過+1
作者: foreverk (文藝青年)   2024-03-05 10:18:00
真的生理上不能接受糞code,就去水需求時間自己補測試補,長久看也是舒服到自己,而且通常不會有人有意見
作者: j50607 (遺世孤人)   2024-03-05 10:58:00
很現實推
作者: Suleika (Suleika)   2024-03-05 13:40:00
智障義大利麵吃得快老實說也不簡單,甚至這種人在工程師裡很稀有,只會抱怨跟會提單子重購又是另一種特質
作者: nacy204327 (♥~超可愛✡小南C~♥)   2024-03-05 13:46:00
超推 馬的新人進來就說要refactor 真的超煩的
作者: superpandal   2024-03-05 15:09:00
為了改而改很糟糕 放任髒code也很糟糕 沒有人喜歡改髒code把自己搞的頭大 用說的都馬很簡單 換到自己就推問題用嘴寫code了 要嘛你是髒code始祖 要嘛你花多倍心思去解開髒code丟給新人 不管年資哪個人不是幹在心裡用舊技術都不是整的一團亂的理由看到這篇又一堆人來偷渡觀念了 很少當新人當然翹著二郎腿要求後面的人
作者: Lleytonhewit (Hewitt)   2024-03-06 01:29:00
這篇 懂的就懂
作者: ukikaz (yuki)   2024-03-08 08:03:00
能完全放任髒code的一定是只維護自己生的垃圾 或是根本不用寫code... 我也想只增加商業價值,但現實就是髒code影響我的生產力了!
作者: benqm300 (人生苦短)   2024-03-23 09:27:00
重構看起來好改的部分或是該統一的部分,其餘的沒空。

Links booklink

Contact Us: admin [ a t ] ucptt.com