跳到主要內容

十年一覺程設夢 讀後感

這篇作者說他自己額外研發出的工作,常常不得公司的青睞,仔細想有幾個原因

  1. 額外做的工作為其他部門的業務。雖然他認為他開發出的功能或想法領先市場一兩年,但是卻可能影響他人的利益。
  2. 所作的方向與頂頭上司認知不同,不認為有價值。

雖說主管或許會喜歡屬下不只做分內的事,如果能更進一步做一些額外的事更好,但是從這個作者的經驗來看,就算多做也不一定是件好事!就像作者做的事,可能可以幫助其他部門增加效益,但是撈過界,這種政治不正確讓他嚐到苦頭。自己自行研發出的功能,主管沒興趣,等到市場出現類似的功能後,被人搶先商機才得見天日。這種都要靠外部的市場壓力,來弭平內部阻力的創新政策。再怎樣雄心壯志的人都會失望吧!

之前看過google,他內部有一個創新模式,我覺得很棒,應該可以解決這些問題,google他們工程師有個很有名的20%自由運用時間,每週有20%的時間可以去做他們想做的事情,但是可以做的事情也是有限制的,他們會有一個pool,裡面放著經過認定可以做的專案,每個人都可以提出自己的創新想法,經過審核後就可以放入這個pool裡面,每個人可以依據自己的興趣選擇pool裡面的專案來做。

以我們的情形或許沒有辦法像google一樣豪氣,可以犧牲20%的產能來創新,但是不一定要花工作的時間,可以利用自己額外的時間,使用這樣的方法,我想有幾個好處。

  1. 讓想做額外研發的人,有條明確的路,不會政治不正確,至少做出的案子也是上司所認同的。
  2. 推廣創新,每個人都可以提出自己特殊的想法,不會囿於一隅,這樣的創新才會多元,不會僅受到少數幾人的影響。
  3. 做自己認為有價值的事。既然是自己選的專案,就算不是自己想出的專案,也是自己有興趣的,這樣的工作,會最讓人有生產力。
  4. 相信有很多功能是市場需要的,但是因為時程/人力需求,排不上專案時程內,但是如果工程師本身有興趣,願意花額外的時間做,或許會收到奇效。
  5. 沒時間壓力的技術評估專案可以納入此塊,讓工程師用自己的時間做評估,沒成效也無妨,不影響成本。

當然,做額外的事也應該有相對應的獎勵,管理者應依據額外專案的完成度,與功能成效給予適當的獎勵。例如多了這個功能,讓業務多賣了幾戶,那麼做此功能的工程師,是不是也可獲得部份分紅,或者此功能讓頻寬費用下降20%,這節省的費用是否可以當成紅利呢?當然獎勵的前提是把本分做好,原本做的專案不能delay,且品質在一定的等級以上,才有資格拿到獎勵。

我認為如果工程師,如果只能在別人限制的範圍做的話,他的貢獻度也就只有那樣了。不像業務,他更上一層樓的機會幾乎等於無限,每多做一個客戶就等於多一個獎勵。工程師的創新或額外的工作,如果能像業務一樣獲得獎勵,這樣不是更好嗎!當然實施這種制度,可能會有幾個隱憂:

  1. 工程師誇大預估專案時程,以方便有時間可以做額外的專案。
  2. 故意將程式寫出部分缺失,再以額外專案改善以獲得獎勵。

這可能會增加專案管理的難度,但是我相信這是可以解決的。而這方法也值得一試。

留言

匿名表示…
十年一覺那篇文章看看就好,我待過他底下,軟體功力不強,沒有version control,eq能力極差,若有興趣你可以像華碩人探聽一下weber這個人的風評。很負面。
Link寫道…
好久以前寫的心得,現在看看就覺得當初想的很理想。沒想到會有人看這篇心得,其實我是看他文章得出的感想,我不會因人廢言,不過從你的回應來看,他應該不是個好主管,也不是做產品出生,沒有version control,應該是做專案或內部系統吧!也工作多了兩年,經歷了金融海嘯,也失業過!唉!肯聽下屬意見的主管可遇不可求,好一點會說官話,不好的就不削或順便罵一頓,官大學問大的感覺越來越嚴重..我越來越沒有創新的意念了..還是自掃門前雪好了..
匿名表示…
某埋怨,散播打擊士氣言論的部屬, 被我限期離職. 因而在網路上攻擊我.
加上 2009 年因 ASUS 首度虧損, 被煽動的一些部下因而離職.
但這些離職的部下, 現在有過得更好嗎 ?

一位去和碩的, 2010 年分紅是 0. 現在華碩股價是和碩的 7 倍.
一位去醫療公司, 又轉到鴻海, 現在回鍋華碩, 變成以前平輩同事的部下.

一位去當淡江大學助理教授, 年薪打五折.
但我透過華碩-淡大產學合作計畫, 來增加他的收入與 credit.

一位去 J-Micro, J-Micro 股價這幾年從最高 146 變成現在 46.
而其主力產品 NAND Flash/USB 3.0 controller 的功能
都被 Intel SharkBay/ARM SoC 整合內建掉.

同期留下來的部屬們, 都已經昇上副理/主任等管理階層.
公司股價也推升到 350.

2013年 公司要管理 5 家代工廠, 外加大陸工資從 RMB 700 up to 2000.
PM/EE 都主動要求我這個單位幫他們建立自動化生產/流程/測試等功能.

而我也成立另外一個軟體部門, 聚焦在演算法開發+GPU 平行運算 for X86/ARM.

時間拉長後, 就能看清事實真相, 就知道當初的堅持是不是正確.

2009 年華碩虧損時, 一堆人在網路上匿名罵沈總是 "阿萊仔",
但 2012 年他重整手持/NB部門, 把股價推升到 NT 300 後.
那些謾罵的匿名者們, 現在到底都躲到哪邊去 ?

跟對有執行力,能真正創造出價值的老闆, 是很重要的.
我很慶幸在 RUN EPC 時, 能受到總經理/副總的肯定.

與其受心懷不滿的同事影響, 更重要是自己能不能判斷現況, 並觀察未來趨勢.

這個網誌中的熱門文章

勝券在握

其實這本書,感覺上寫的有點雜,比上一本講巴非特的書更難懂,兩個講的東西其實是一致的。投資原則便是先選產業,再選公司,慎選時機進場。只買了解的企業是價值投資一貫的原則。價值投資的書大概就先看到這裡了,彼得林區不知道是屬於那一類的,接下來大概會看這部份的書。暫時的目標是把杜金龍介紹的書單看完,真的還不少。接下來的投資會以巴菲特的方法來做,感覺上這比較適合我,練習把漲跌不當一回事,對我而言真的很重要。期權大概不會再玩了,買了以後一直在看漲跌,令人受不了。工作時都不能專心。 就價值投資人而言,真的不需要我們的產品,因為第一點就把我們程式特性打死,不理會股票市場的漲跌,這樣報價功能就沒什麼意義了,價值投資根本不需要技術分析,除非我們能提供相關價值投資的資訊,但我們基本分析真的很爛,看不到什麼資料。有機會我來思考一下價值投資到底要什麼資料,能不能把他寫成一個可運用的程式。 以下是我認為重要的書摘,其實這也只包含最後一章,我認為也只有這章值得做書摘。 巴非特相信使用短期價格來判斷一家公司的成功與否是愚蠢的。取而代之的是,他要公司向他報告因經濟實力成長所獲得的價值,一年一次,他固定檢查幾個變數: 初始的股東權益報酬率。 營運毛利、負債水準與資本支出需求的變化。 該公司的現金產生能力。 如果這些經濟指標正在進展,他知道長期下來,結果會反應在股價上。短期之內,股價所發生的是是不合常理的。 投資策略 不理會股票市場每日的漲跌 不擔心經濟情勢。 買下一家公司,而不是股票 管理企業的投資組合 巴非特原則 企業原則 這家企業是簡單且可以了解的 了解一家企業如何產生利潤的相關經濟活動。 這家企業的營運歷史是否穩定 他必須經得起時間的考驗。 這家企業的長期發展前景是否看好 市場特許權,五力分析 經營原則 經營者是否理性 理性的經營者將只會把多餘的現金,投資在那些產生較資本成本報酬率為高的計畫裡。 經營者對他的股東是誠實坦白的 報告時能知道營業部門如何營業,坦承失敗,了解公司的目的是使股東權益報酬率達到最大。 經營者是會盲從其他法人機構的行為 當心『其他公司也這麼做,一定沒問題』為自己行為辯護的經營者。衡量經營者競爭力的一個方法是,看他們如何運用自己的思考能力以避免依附群眾心理。 財務原則 把重點集中...

用 AI Debug 的迷思:當建議越改越糟時

現在許多開發者習慣用 AI 來協助 debug,但在實務上常遇到一種情況: 依照 AI 建議改了兩三輪後,錯誤仍然存在,甚至越改越複雜。 這種狀況其實有幾個常見的盲點,值得特別注意。 1. 先回到「上一個正常版本」 當你已經按照 AI 的方向修了好幾次但問題仍未解決時,最有效的第一步是: 回到上一個正常工作的版本,縮小問題來源。 許多 bug 並不是你正在看的那段程式碼造成的,而可能是: 同事剛好修改了某個底層模組 某個 shared component 產生 side effect Auto Layout 層級重新 layout 時觸發 crash 如果只是盯著眼前的 function 修,反而容易被誤導。 2. AI 沒有看到你的整個專案 AI 通常只能根據你貼出的片段判斷問題,這代表它不知道: 你的 view hierarchy 裡是否有其他 constraint 影響 layout 某些 model 是否被 extension 修改過 父層或子層邏輯是否干擾目前的行為 整個專案採用的 concurrency 模型是什麼 因此,AI 可能會朝著完全錯誤的方向修,導致反覆修改卻無法解決。 3. Swift 6 例子:錯誤真正原因常不在你修改的那一行 例如開發者常遇到的錯誤: passing closure as a 'sending' parameter risks causing data races 許多人(包含 AI)會開始從 function 內部調整,但這類錯誤真正的關鍵通常是: 傳進去的物件沒有實作 Sendable。 也就是說,你不是要改 function,而是要回頭檢查: 傳入的 model / struct / class 裡面是否有 non-Sendable 成員 是否需要標註 @unchecked Sendable 如果 AI 沒看到相關檔案,自然很難找到正確方向。 結語:AI 是工具,不是預言機 AI 很適合用來: 解釋概念 協助產生測試程式 提供重構建議 釐清你已懷疑的方向 但在 debug 狀況下,以下三件事更重要: 回到上一版,縮小差異範圍。 釐清真正問題來...

解決 CI Trust Issue:Target Must Be Enabled Before It Can Be Used

📱 iOS開發 | 🔧 CI/CD | 💻 Xcode | 🐛 除錯筆記 🔴 問題描述 這兩天在跑 CI 時突然出現錯誤訊息: Package@swift-6.0.swift:PACKAGE-TARGET:CasePathsMacros: error: Target 'CasePathsMacros' must be enabled before it can be used 🤔 嘗試過的解法 💬 Claude 的建議 首先詢問了 Claude,得到以下步驟: 先更新 swift-case-paths 到最新版本 確保使用 "Up to Next Major Version" 執行 File → Packages → Reset Package Caches Clean Build Folder (Cmd + Shift + K) 重新 Build 結果: 一看就知道沒用 😅 🤖 ChatGPT 的建議 接著試了 ChatGPT 的解法,主要是降低引用到的 package 版本。繞了一圈,還是沒用。 ✅ 最終解決方案 最後還是回到 Google,找到了真正有效的解法。針對這個 macro fingerprint validation 問題,有三種解決方式: 📌 方法一:本機開發用(Terminal 指令) defaults write com.apple.dt.Xcode IDESkipMacroFingerprintValidation -bool YES 📌 方法二:xcodebuild 參數 在執行 xcodebuild 指令時,加上 -skipMacroValidation 參數 📚 參考連結: https://vocus.cc/article/690779ebfd89780001859b14 📌 方法三:CI 正統做法 ⭐️(推薦) 步驟 1: 在專案根目錄建立資料夾 ci_scripts 步驟 2: 在此資料夾中建立腳本 ci_post_clone.sh ,內容如下: #!/bin/zsh mkdir -p ~/Library/org.swift.swiftpm/security/ cp macros.js...