油膩代碼大叔與蝴蝶效應(yīng)
前些天突然覺得自己是不是得了老年癡呆,腦子總忘事,遇到佳純同學(xué)喊她姜楠,遇到周聰喊她“洋蔥”。
自己已是油膩大叔年紀(jì)了,大肚腩、大臉和雙下巴已經(jīng)陪伴我多年。昨天晚上還瘋狂的吃了一頓火鍋,吃的時(shí)候幸福感是爆表,過后想想我應(yīng)該很快就超越油膩大叔,變成肥肉大叔。這可能是小時(shí)候做過些壞事,上天對(duì)我的懲罰。
哎呀,寫著寫著饞蟲上來了,叫個(gè)小龍蝦外賣吃一吃,不過小龍蝦吃起來好麻煩,沒有吃火鍋爽,可以大口大口涮毛肚吃。
我想像《蝴蝶效應(yīng)》的伊萬一樣回到過去改變自己。不過像我這種從小學(xué)習(xí)不好的,再怎么改變也應(yīng)該就這樣了。能改變什么呢?
就像伊萬為了彌補(bǔ)錯(cuò)誤,返回過去試圖消除痕跡,但總是事與愿違,并沒有變好而是更糟糕。于是反反復(fù)復(fù),他奔波于日益混亂的過去與現(xiàn)實(shí)之間,直到不可挽回的結(jié)局。伊萬試圖改變過去,希望能與他暗戀的凱蕾一起幸福生活的夢(mèng)想,也成為了泡影。
既然這樣,“過去的已然成為過去,不要把精力用在追憶并后悔人生轉(zhuǎn)折點(diǎn)時(shí)作出的任何決定”。該吃吃該喝喝,做個(gè)沒心沒肺的人好像也挺好。
回歸正題。
當(dāng)我在設(shè)計(jì)開發(fā)一個(gè)系統(tǒng)時(shí),一開始覺得自信滿滿,一切在控制當(dāng)中。隨著時(shí)間流逝,出現(xiàn)了各種各樣的問題,項(xiàng)目交付時(shí)間一二三的被延期。心里想自己到底做錯(cuò)了什么,為什么呢?
當(dāng)我在維護(hù)一個(gè)系統(tǒng)時(shí),為什么總是不穩(wěn)定,修復(fù)一個(gè)BUG又出現(xiàn)另一個(gè),出問題后不斷的重啟系統(tǒng),總是被業(yè)務(wù)方投訴,為什么它就不能老老實(shí)實(shí)的好好運(yùn)行,讓我省點(diǎn)心。我們到底做錯(cuò)了什么?
先來看看我們開發(fā)一個(gè)系統(tǒng)需要做些什么吧:
- 首先產(chǎn)品會(huì)出PRD,大家一起評(píng)審,此時(shí)程序員需要去理解其中的邏輯:業(yè)務(wù)語言、流程、功能、異常;
- 接著定義業(yè)務(wù)架構(gòu)和系統(tǒng)架構(gòu),是分布式還是單體,業(yè)務(wù)和系統(tǒng)模塊怎么劃分,邊界如何界定,業(yè)務(wù)上下游依賴和邊界是什么;
- 接著開始進(jìn)行項(xiàng)目搭建,用Java還是Go,用Git還是SVN,是基于Maven構(gòu)建還是Gradle;
- 接著進(jìn)行一些技術(shù)選型,用SpringCloud還是Dubbo,要不要用Guava,用Slf4j還是直接Log4j;存儲(chǔ)選什么;用不用緩存;
- 明確分工,構(gòu)建各自的模塊和系統(tǒng),碼代碼;
- 進(jìn)行模塊集成或系統(tǒng)集成;
- 測(cè)試、交付上線。
這是比較理想的一個(gè)開發(fā)方式,實(shí)際過程要復(fù)雜很多。我們會(huì)遇到需求不明確,需求錯(cuò)誤,細(xì)節(jié)考慮不周全,技術(shù)上不可行等等很多問題。
在開發(fā)過程中還有一些非功能性需求要考慮:
- 提升工程開發(fā)效率;
- 魯棒性、可維護(hù)性、可擴(kuò)展性;
- 高并發(fā)、高可用、SLA;
- 兼容性;
- A/B測(cè)試;
- 可回歸測(cè)試;
- DevOps;
- 管理復(fù)雜度;
還有我們解決問題的方式:
- 當(dāng)我們?cè)诮鉀Q一個(gè)類似問題時(shí),有些人是通過抽象來解決;有些人覺得反正代碼邏輯超簡單,復(fù)制代碼來解決;
- 有些不應(yīng)該出生的代碼出生了,維護(hù)一些亂七八糟的代碼;
- if/else嵌套超過三層;
- 看框架源碼又不能幫我提高寫代碼的速度,浪費(fèi)我時(shí)間;
- 反正我能看懂,不寫注釋和文檔了;
- 復(fù)雜的解決方案沒有迭代優(yōu)化;
- 明天就上線,今天必須交付,然后就沒然后了;
- 重啟來解決問題;
- 不去學(xué)習(xí)解決問題的工具;
- ……
可以看出開發(fā)一個(gè)系統(tǒng)從來不是一件簡單的事情,除了完成業(yè)務(wù)邏輯,還要考慮很多非功能性需求,其中一個(gè)沒有做好都會(huì)引起蝴蝶效應(yīng)。用戶/數(shù)據(jù)量大會(huì)導(dǎo)致大的風(fēng)暴,而用戶/數(shù)據(jù)量小可能就是下點(diǎn)小雨。
蝴蝶效應(yīng)定義:
“蝴蝶效應(yīng)是指在一個(gè)動(dòng)力系統(tǒng)中,初始條件下微小的變化能帶動(dòng)整個(gè)系統(tǒng)的長期的巨大的連鎖反應(yīng)。”
我們看過的源代碼、看過的書并不是沒用的,每一個(gè)知識(shí)可能在未來的某一時(shí)刻被我用到,學(xué)習(xí)會(huì)使我的思路開放,而不是封閉。通過不斷微小的學(xué)習(xí),觸發(fā)蝴蝶效應(yīng),得到巨大的收獲。
不過我好像已經(jīng)走上了另一條不歸路,油膩代碼大叔之路越走越踏實(shí)了!
【本文是51CTO專欄作者張開濤的原創(chuàng)文章,作者微信公眾號(hào):開濤的博客( kaitao-1234567)】