## 做需求與做需求的差異
每一個程序員都是從剛畢業做需求開始,為什么有的人逐漸成為大牛,主導大型技術項目或走向團隊管理崗位,而有的人一直還在做需求。我覺得這里面的差異在于,每一個對做需求這件事的理解有所不同。
這里面的差異在于,你是抱著一種什么樣的心態去完成這個需求,是把這個需求做到極致,還是只是當做任務完成這個需求,達到產品想要的功能就行。這兩個表面上看似差不多其實相差極大,差異在于,你有沒有站在更高的角度,希望這件事做到完美。從需求角度有沒有思考產品設計當中的缺陷,能不能反向為產品設計提供建議,從技術角度能不能做到高質量高兼容性無bug,以及下次再有類似的需求能不能快速高效率的迭代。
用一句話來描述就是,能不能跳出自己是一個程序員是一個被動執行人的角色,而是將自己當做產品當做技術負責人的心態去做這件事。
完成需求,不僅僅是滿足產品的基本功能,而是一場對技術與藝術邊界的探索。我們不再滿足于僅僅是任務的執行者,而是渴望成為需求的塑造者。
## 業務需求該怎么做
知易行難,如果一開始做不到,那就先著眼小事,關注細節,從需求開始的需求評審,編寫技術方案文檔,設計文檔,到開發的代碼注釋,結構設計,保證高質量,完善無漏洞的代碼邏輯,再到異常埋點,指標監控,線上可用性運維等等,認真對待一個需求的每一個環節。
當你自認為已經做好整個流程的每一件小事之后,接下來可以 通過深入細節,思考整個流程是否存在問題。做需求過程中溝通協作的有沒有問題,流程規范的有沒有問題,機制環節哪方面問題,代碼公共基礎能力的是否有缺失,開發過程中你所遇到的問題是不是一個通用問題,能不能抽象出一個公共庫解決大家的問題,能不能制定一個SOP的解決方案流程,亦或是提煉出一個最佳實踐在組內外分享經驗。
通過這些一件件小事來鍛煉自己解決問題的能力,以及更深層級的發現問題的能力。再通過不斷的發現問題,思考問題出現的原因,拿出解決方案,最終落地解決了自己或組內或協作方的問題,鍛煉自己的綜合能力逐步慢慢成長。
## 技術深度
說了這么多,你可能會說,這跟我問的技術深度有什么關系?我想說:拋開業務需求談技術深度都是耍流氓。
舉一個例子,數據可視化方面`3D Three.js`,視頻直播方面的`FFmpeg`編解碼壓縮,客戶端安全方面的攻防滲透,每一個都是有技術深度的事情,但問題是即使你掌握了這些領域擁有了非常高的技術深度之后呢,不能應用于業務需求,不能解決產品急迫要解決的問題,不能完成你老板的OKR,達成部門的戰略目標,還是英雄無用武之地(當然你也可以選擇一個可以用得上的團隊,那是就是另外一回事了)。
由于這些單點的有技術深度的事情,不能為你帶來直觀和顯而易見的 「回報」(也就是顏如玉 黃金屋與金榜題名),也就間接的打擊了積極性(當然自己對某門技術感興趣而鉆研的不再本次討論之列)。所以提升自己的技術深度,最好的方式還是在公司業務中,發現有深度的事,然后去在攻克這個問題的過程中,提升了自己的技術深度,即跟隨公司業務的發展的同時自身也獲得了成長,你用技術能力為公司解決了業務發展過程中的問題,自然也就從公司獲得了該有的回報。這是一個ROI投入產出比最高的獲得技術深度的方式。
## 獲取做有深度事情的授權
當想明白獲取技術深度的路徑之后,接下來要解決的就是,如何讓領導給你安排有技術深度的事情?
業務發展中有很多有技術深度有技術難度的事情,為什么領導要安排你來做這件事呢?你憑什么讓領導覺得你 「有能力」 也 「有意愿」 來完成這件事?能力與意愿是作為領導在分配工作當中的最重要的兩個決策項(有機會的話我會再寫一篇,從管理視角是如何做分工的)。既然你能提問如何積累技術深度,我相信你一定是有強烈意愿的,那么剩下的就是如何讓領導認為你有完成這個有技術深度的事情的能力?最簡單來講就是我在前面講的,你能不能在開發需求中做到深度思考,追求極致,精益求精,有責任心,有主人翁意識與主R意識,在每件小事中能做到 「自閉環」,之后才會逐步讓你承擔更大范圍更高挑戰更大深度的事情,形成正向循環。
這也是我前面為什么要先重點強調做好每一件小事的重要性。
## 技術深度不是唯一標準
作為一個程序員,在職業生涯的初期,確實是以技術深度也就是技術能力作為最大的衡量標準。但隨著職業生涯的發展,職級從L5到L8,站在從公司角度,對一個人的需求,也會從能完成一個業務需求,變成能帶領一幫人完成一個更大的維度的需求,能不能為組織解決問題,為事業部達成戰略目標,對人的要求的重心也會慢慢發生變化,這種變化可以參考公司的職級能力模型體系的雷達圖。
所以一味的追求積累技術深度就跑偏了,但不是說技術深度不重要,技術能力是作為程序員的安身立命之本,但是在積累技術深度的同時,也需要學習鍛煉技術深度以外的能力。具體到底是什么其他能力,這就夠再展開好幾篇文章的篇幅了,今天在這就不細說了,有機會可以談談我對這方面的理解。
## 小結
故不積跬步無以至千里,不積小流無以成江海。先從做好每一件小事開始,把每個業務需求做到120分,深度思考,發現問題,解決問題,逐步建立起靠譜有責任心技術牛的人設,逐步負責有技術難度的事情,跟隨公司業務發展積累自己的業務領域經驗與技術深度,從而獲得雙贏的回報。
這是我對如何積累技術深度這件事的理解,或許會有一些片面和偏激,畢竟不是誰都有一個能知人善任的好領導,不是誰都能遇到一個快速發展的業務,不是誰都能遇到有技術難度與技術挑戰的場景,無論我怎么說,都會有幸存者偏差的存在。
努力與機遇并存,機遇可遇不可求,所以我們能做的事,就是學會正確做事的思路和方法,并為之堅持不懈的踐行它。知易行難,學會方法容易,堅持踐行難于上青天。自己該做的都做好了,機遇來了就可以抓住,即使抓不住,你也有了「選擇的能力」,有了選擇更好機遇更好公司的能力。
技術深度的積累不是一蹴而就的,它需要我們持之以恒的努力。從做好每一件小事開始,逐步建立起自己的技術體系和業務理解。當我們真正做到這一點時,無論遇到什么樣的挑戰和機遇,我們都有能力去抓住它,實現自己的職業目標。
在這個充滿挑戰和機遇的時代,讓我們一起努力,不斷提升自己的技術深度和綜合能力,為公司創造更大的價值,也為自己的職業生涯贏得更多的可能性。
- 設計模式系列
- 工廠方法模式
- 序言
- Windows程序注冊為服務的工具WinSW
- 基礎
- 安裝
- 開發規范
- 目錄結構
- 配置
- 快速入門
- 架構
- 請求流程
- 架構總覽
- URL訪問
- 容器和依賴注入
- 中間件
- 事件
- 代碼層結構
- 四個層次
- 路由
- 控制器
- 請求
- 響應
- 數據庫
- MySQL實時同步數據到ES解決方案
- 阿里云DTS數據MySQL同步至Elasticsearch實戰
- PHP中的MySQL連接池
- PHP異步非阻塞MySQL客戶端連接池
- 模型
- 視圖
- 注解
- @SpringBootApplication(exclude={DataSourceAutoConfiguration.calss})
- @EnableFeignClients(basePackages = "com.wotu.feign")
- @EnableAspectJAutoProxy
- @EnableDiscoveryClient
- 錯誤和日志
- 異常處理
- 日志處理
- 調試
- 驗證
- 驗證器
- 驗證規則
- 擴展庫
- 附錄
- Spring框架知識體系詳解
- Maven
- Maven和Composer
- 構建Maven項目
- 實操課程
- 01.初識SpringBoot
- 第1章 Java Web發展史與學習Java的方法
- 第2章 環境與常見問題踩坑
- 第3章 springboot的路由與控制器
- 02.Java編程思想深度理論知識
- 第1章 Java編程思想總體
- 第2章 英雄聯盟的小案例理解Java中最為抽象的概念
- 第3章 徹底理解IOC、DI與DIP
- 03.Spring與SpringBoot理論篇
- 第1章 Spring與SpringBoot導學
- 第2章 Spring IOC的核心機制:實例化與注入
- 第3章 SpringBoot基本配置原理
- 04.SprinBoot的條件注解與配置
- 第1章 conditonal 條件注解
- 第2章 SpringBoot自動裝配解析
- 05.Java異常深度剖析
- 第1章 Java異常分類剖析與自定義異常
- 第2章 自動配置Url前綴
- 06.參數校驗機制與LomBok工具集的使用
- 第1章 LomBok工具集的使用
- 第2章 參數校驗機制以及自定義校驗
- 07.項目分層設計與JPA技術
- 第1章 項目分層原則與層與層的松耦合原則
- 第2章 數據庫設計、實體關系與查詢方案探討
- 第3章 JPA的關聯關系與規則查詢
- 08.ORM的概念與思維
- 第1章 ORM的概念與思維
- 第2章 Banner等相關業務
- 第3章 再談數據庫設計技巧與VO層對象的技巧
- 09.JPA的多種查詢規則
- 第1章 DozerBeanMapper的使用
- 第2章 詳解SKU的規格設計
- 第3章 通用泛型Converter
- 10.令牌與權限
- 第1章 通用泛型類與java泛型的思考
- 常見問題
- 微服務
- demo
- PHP中Self、Static和parent的區別
- Swoole-Cli
- 為什么要使用現代化PHP框架?
- 公眾號
- 一鍵部署微信公眾號Markdown編輯器(支持適配和主題設計)
- Autodesigner 2.0發布
- Luya 一個現代化PHP開發框架
- PHPZip - 創建、讀取和管理 ZIP 文件的簡單庫
- 吊打Golang的PHP界天花板webman壓測對比
- 簡潔而強大的 YAML 解析庫
- 推薦一個革命性的PHP測試框架:Kahlan
- ServBay下一代Web開發環境
- 基于Websocket和Canvas實現多人協作實時共享白板
- Apipost預執行腳本如何調用外部PHP語言
- 認證和授權的安全令牌 Bearer Token
- Laradock PHP 的 Docker 完整本地開發環境
- 高效接口防抖策略,確保數據安全,避免重復提交的終極解決方案!
- TIOBE 6月榜單:PHP穩步前行,編程語言生態的微妙變化
- Aho-Corasick字符串匹配算法的實現
- Redis鍵空間通知 Keyspace Notification 事件訂閱
- ServBay如何啟用并運行Webman項目
- 使用mpdf實現導出pdf文件功能
- Medoo 輕量級PHP數據庫框架
- 在PHP中編寫和運行單元測試
- 9 PHP運行時基準性能測試
- QR碼生成器在PHP中的源代碼
- 使用Gogs極易搭建的自助Git服務
- Gitea
- webman如何記錄SQL到日志?
- Sentry PHP: 實時監測并處理PHP應用程序中的錯誤
- Swoole v6 Alpha 版本已發布
- Proxypin
- Rust實現的Redis內存數據庫發布
- PHP 8.4.0 Alpha 1 測試版本發布
- 121
- Golang + Vue 開發的開源輕量 Linux 服務器運維管理面板
- 內網穿透 FRP VS Tailscale
- 新一代開源代碼托管平臺Gitea
- 微服務系列
- Nacos云原生配置中心介紹與使用
- 輕量級的開源高性能事件庫libevent
- 國密算法
- 國密算法(商用密碼)
- GmSSL 支持國密SM2/SM3/SM4/SM9/SSL 密碼工具箱
- GmSSL PHP 使用
- 數據庫
- SQLite數據庫的Web管理工具
- 阿里巴巴MySQL數據庫強制規范
- PHP
- PHP安全測試秘密武器 PHPGGC
- 使用declare(strict_types=1)來獲得更健壯的PHP代碼
- PHP中的魔術常量
- OSS 直傳阿里騰訊示例
- PHP源碼編譯安裝APCu擴展實現數據緩存
- BI性能DuckDB數據管理系統
- 為什么別人可以是架構師!而我卻不是?
- 密碼還在用 MD5 加鹽?不如試試 password_hash
- Elasticsearch 在電商領域的應用與實踐
- Cron 定時任務入門
- 如何動態設置定時任務!而不是寫死在Linux Crontab
- Elasticsearch的四種查詢方式,你知道多少?
- Meilisearch vs Elasticsearch
- OpenSearch vs Elasticsearch
- Emlog 輕量級開源博客及建站系統
- 現代化PHP原生協程引擎 PRipple
- 使用Zephir編寫C擴展將PHP源代碼編譯加密
- 如何將PHP源代碼編譯加密,同時保證代碼能正常的運行
- 為什么選擇Zephir給PHP編寫動態擴展庫?
- 使用 PHP + XlsWriter實現百萬級數據導入導出
- Rust編寫PHP擴展
- 阿里云盤開放平臺對接進行文件同步
- 如何構建自己的PHP靜態可執行文件
- IM后端架構
- RESTful設計方法和規范
- PHP編譯器BPC 7.3 發布,成功編譯ThinkPHP8
- 高性能的配置管理擴展 Yaconf
- PHP實現雪花算法庫 Snowflake
- PHP官方現代化核心加密庫Sodium
- pie
- 現代化、精簡、非阻塞PHP標準庫PSL
- PHP泛型和集合
- 手把手教你正確使用 Composer包管理
- JWT雙令牌認證實現無感Token自動續期
- 最先進PHP大模型深度學習庫TransformersPHP
- PHP如何啟用 FFI 擴展
- PHP超集語言PXP
- 低延遲雙向實時事件通信 Socket.IO
- PHP OOP中的繼承和多態
- 強大的現代PHP高級調試工具Kint
- PHP基金會
- 基于webman+vue3高質量中后臺框架SaiAdmin
- 開源免費的定時任務管理系統:Gocron
- 簡單強大OCR工具EasyOCR在PHP中使用
- PHP代碼抽象語法樹工具PHP AST Viewer
- MySQL數據庫管理工具PHPMyAdmin
- Rust編寫的一款高性能多人代碼編輯器Zed
- 超高性能PHP框架Workerman v5.0.0-beta.8 發布
- 高并發系列
- 入門介紹及安裝
- Lua腳本開發 Hello World
- 執行流程與階段詳解
- Nginx Lua API 接口開發
- Lua模塊開發
- OpenResty 高性能的正式原因
- 記一次查找 lua-resty-mysql 庫 insert_id 的 bug
- 包管理工具OPM和LuaRocks使用
- 異步非阻塞HTTP客戶端庫 lua-resty-http
- Nginx 內置綁定變量
- Redis協程網絡庫 lua-resty-redis
- 動態HTML渲染庫 lua-testy-template
- 單獨的
- StackBlitz在線開發環境
- AI
- 基礎概念
- 12312
- 基礎鏡像的坑
- 利用phpy實現 PHP 編寫 Vision Transformer (ViT) 模型
- 語義化版本 2.0.0