一些想法隨筆寫寫,沒什麼組織還請見諒
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能大幅縮短寫程式的時間,我是樂見其成
代表我們有更多時間去做其他更有價值的事情