程序員,特別是一個新手程序員而言,工作的壓力會讓你整天灰頭土臉,了解一些實(shí)用的小技巧,積極的去面對漫長的程序員生涯。
leader問任務(wù)時間,若答不上來,可能是任務(wù)拆分還不夠細(xì)。寧可多算一周,不可少估一天。過于“樂觀”容易讓boss受驚嚇。最有用的語言是English。其次的可能是Python。百聞不如一見。畫出結(jié)果,一目了然。調(diào)試耗時將大大縮短。重構(gòu)是程序員的主力技能,工作日志能提升腦容量,先用profiler調(diào)查,才有單元測試總是合算的。不要先寫框架再寫實(shí)現(xiàn)。最好反過來,從原型中提煉框架。代碼結(jié)構(gòu)清晰,其它問題都不算事兒。
編程之事,隔離是方向,起名是關(guān)鍵,測試是主角,調(diào)試是補(bǔ)充,版本控制是后悔藥。一行代碼一個兵。形成建制才能有戰(zhàn)斗力。單位規(guī)模不宜過大,千人班,萬人排易成萬人坑。重構(gòu)/優(yōu)化/修復(fù)Bug,同時只能作一件。簡單模塊注意封裝,復(fù)雜模塊注意分層。
人腦性能有限,整潔勝于雜亂。讀不懂的代碼,嘗試整理下格式; 不好用的接口,嘗試重新封裝下。迭代速度決定工作強(qiáng)度。想多快好省,就從簡化開發(fā)流程,加快迭代速度開始。
好的項(xiàng)目作風(fēng)硬派,一鍵測試,一鍵發(fā)布,一鍵部署; 爛的項(xiàng)目生性猥瑣,口口相傳,不立文字,神神秘秘。編碼不要畏懼變化,要擁抱變化。常充電。程序員只有一種死法:土死的。
忘掉優(yōu)化寫代碼。過早優(yōu)化等同惡意破壞;忘掉代碼作優(yōu)化。優(yōu)化要基于性能測試,而不是糾結(jié)于字里行間。最好的工具是紙筆;其次好的是markdown。
與主流意見/方法/風(fēng)格/習(xí)慣相悖時,先檢討自己最可靠。出現(xiàn)bug主動查,不管是不是你的。這能讓你業(yè)務(wù)能力猛漲、個人形象飆升; 如果你的bug被別人揪出來.....呵呵,那你會很被動不知怎么選技術(shù)書時就挑薄的。起碼不會太貴,且你能看完。
資源、代碼應(yīng)一道受版本管理。資源匹配錯誤遠(yuǎn)比代碼匹配錯誤更難排查。不要基于想象開發(fā), 要基于原型開發(fā)。原型的價值是快速驗(yàn)證想法,幫大家節(jié)省時間。
東西交付之前偷偷測試一遍, 問別人之前偷偷谷歌一下,版本發(fā)布之前反復(fù)檢查七八遍,用check-list, 用谷歌,用英文搜索。
做十件事不如做好一件事,奪取話語權(quán)只有一條路徑,就是超出別人的預(yù)期,心要皮實(shí),但話語和臉皮要柔軟,記住有句老話叫,伸手不打笑臉人。 先假裝你就是專家,慢慢為了裝得像,不得不去學(xué),假的就成真了。
序列化首選明文文本 。諸如二進(jìn)制、混淆、加密、壓縮等等有需要時再加。編譯器永遠(yuǎn)比你懂微觀優(yōu)化。只能向它不擅長的方向努力。不要定過大、過遠(yuǎn)、過細(xì)的計(jì)劃。即使定了也沒有用。至少半數(shù)時間將花在集成上。時間,時間,時間總是不夠。
git是最棒的。簡單,可靠,免費(fèi)。僅對“可預(yù)測的非理性”拋斷言。Log要寫時間與分類。并且要能重定向輸出。注釋是稍差的文檔。更好的是清晰的命名。讓代碼講自己的故事。造輪子是很好的鍛煉方法。前提是你見過別的輪子。
code review最好以小組/結(jié)對的形式。對業(yè)務(wù)有一定了解,建議會更有價值(但不絕對)。而且不會成為負(fù)擔(dān)。管理員個人review則很容易成team的瓶頸。提問前先做調(diào)研。問不到點(diǎn)上既被鄙視,又浪費(fèi)自己的時間。永遠(yuǎn)別小看程序媛
新手程序員和經(jīng)驗(yàn)豐富的程序員的一個很大區(qū)別來自于debug的能力。在設(shè)計(jì)和建設(shè)網(wǎng)站時不能只知道表面的,卻不知深層次的問題,程序員必須了解的更深,明白的更多,才能從新手變?yōu)榇笊瘛?br />
本文地址:http://www.youmaike.com//article/2378.html