PHP代碼維護(hù),重構(gòu)變困難的4種原因分析
本文分析講述了PHP代碼維護(hù),重構(gòu)變困難的4種原因。分享給大家供大家參考,具體如下:
代碼維護(hù),重構(gòu)是件很令人不爽的一件事。以下幾種情況,會(huì)讓代碼維護(hù)和重構(gòu)變得很困難。
1. 項(xiàng)目開始時(shí),大家規(guī)定好一些代碼規(guī)范,在一定的規(guī)范下進(jìn)行開發(fā),但是人的思想是不一樣的,也就是說每個(gè)功能不同的人實(shí)現(xiàn)的邏輯可能會(huì)有這樣那樣的不同,導(dǎo)致了一些人不愿意去看別人代碼,要改別人代碼,首先要了解這個(gè)人當(dāng)時(shí)是怎么想的,他的邏輯是怎么樣的。所以有很多人的想法是有那看別人代碼的時(shí)間,我就重新做好了。這種想法不要有,看別人代碼也能學(xué)到不少東西。如果都這樣想,我想冗余代碼會(huì)越來越多,后期重構(gòu)會(huì)變的越來越困難。
2. 做程序的一般跳槽都比較頻繁,項(xiàng)目開始的時(shí)候,是5個(gè)人(項(xiàng)目創(chuàng)始人)開發(fā)的,等項(xiàng)目上線了,可能有人離職了。人手不夠,公司招人。項(xiàng)目創(chuàng)始人呢,對(duì)新招的人,不太信認(rèn),怕修改原代碼會(huì)導(dǎo)致上線的功能出問題,所以就出了新規(guī)定,最好不要修改上線過的程序,如果需求變動(dòng),最好重新寫class或者是function,這樣的話,代碼會(huì)變的越來越多??赡軙?huì)出現(xiàn)幾個(gè)class都差不多,或者多個(gè)function的功能差不多。
3. 數(shù)據(jù)庫冗余字段,冗余表過多,也會(huì)讓代碼維護(hù)變的十分困難。因?yàn)楣δ軆?yōu)化,或者新需求,導(dǎo)致原有表結(jié)構(gòu)根本不能滿足新需求,這個(gè)時(shí)候,就會(huì)去表里添加字段,或者掛接另一個(gè)表,長(zhǎng)期以往,數(shù)據(jù)庫變的很臃腫,數(shù)據(jù)庫一大,代碼肯定就不用說了,程序都是圍繞著數(shù)據(jù)來的,冗余字段,冗余表都要維護(hù)的,不然數(shù)據(jù)就不統(tǒng)一了。必要的冗余可以減少數(shù)據(jù)庫查詢,如果過多,只會(huì)事得其返。所以在修改數(shù)據(jù)庫時(shí)更要考慮清楚,考慮將來數(shù)據(jù)庫和代碼要重構(gòu)的情況。
4. 個(gè)人原因是最主要的原因,首先要有分塊思想,也可以說是oop思想,這種思想是在實(shí)戰(zhàn)中養(yǎng)成的,這個(gè)是要一定時(shí)間的。不要為了急著去實(shí)現(xiàn)功能而忽視了整體考慮。假如來了一個(gè)新需要,我會(huì)首先考慮怎么實(shí)現(xiàn)這個(gè)需求,有了思路后,我也不會(huì)急著去開發(fā)這個(gè)功能,我還會(huì)在考慮這個(gè)功能模塊,會(huì)不會(huì)用在其他地方?如果其他地方用,怎么樣讓其他地方用著更方便。我會(huì)讓所以調(diào)用這個(gè)功能模塊的地方,接口只有一個(gè)。然后我才會(huì)著手去開發(fā)。還有一點(diǎn),不要相信需求定下來就不會(huì)變了,不會(huì)的。人的想法很多,開發(fā)代碼的時(shí)候,這一點(diǎn)也要考慮進(jìn)去,所以統(tǒng)一的接口在需求變動(dòng)時(shí),我只要修改一個(gè)地方,其他地方都可以改掉。如果這樣考慮了,前期開發(fā)時(shí),時(shí)間會(huì)多一點(diǎn),但是后期維護(hù)就快很多。
小結(jié)一下,有了上面4點(diǎn),重構(gòu)數(shù)據(jù)庫,重構(gòu)代碼將是必然的
1. 人的思想不可能一樣,大家都在盡量往一處想,但是總會(huì)有這樣,那樣的不同。
2. 急于要完成功能,而不深入了解別人代碼。研究別人代碼不如重新開發(fā)快,這種思想不好。
3. 數(shù)據(jù)庫冗余,這個(gè)我個(gè)人覺得必然會(huì)出現(xiàn)的,一個(gè)項(xiàng)目做大,做強(qiáng),一定是在不斷的成長(zhǎng),成長(zhǎng)過程中,數(shù)據(jù)庫不可能是一成不變的。
4. 缺少分塊思想,我覺得一個(gè)項(xiàng)目,就是很多功能獨(dú)立的小塊通過一定線串起來的,代碼重構(gòu)也就是把這些小塊的重新組合,當(dāng)然各個(gè)小塊,在重構(gòu)前后實(shí)現(xiàn)的功能會(huì)不一樣,但它還是為了實(shí)現(xiàn)一定的功能,只不過由舊變新而已。
上面的幾點(diǎn)是我在開發(fā)項(xiàng)目過程實(shí)際遇到的,歡迎大家補(bǔ)充。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP基本語法入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》及《php優(yōu)秀開發(fā)框架總結(jié)》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- 五款PHP代碼重構(gòu)工具推薦
- PHP 雜談《重構(gòu)-改善既有代碼的設(shè)計(jì)》之五 簡(jiǎn)化函數(shù)調(diào)用
- PHP 雜談《重構(gòu)-改善既有代碼的設(shè)計(jì)》之四 簡(jiǎn)化條件表達(dá)式
- PHP 雜談《重構(gòu)-改善既有代碼的設(shè)計(jì)》之三 重新組織數(shù)據(jù)
- PHP 雜談《重構(gòu)-改善既有代碼的設(shè)計(jì)》之二 對(duì)象之間搬移特性
- PHP 雜談《重構(gòu)-改善既有代碼的設(shè)計(jì)》之一 重新組織你的函數(shù)
- rephactor 優(yōu)秀的PHP的重構(gòu)工具
- PHP代碼重構(gòu)方法漫談
相關(guān)文章
php定義一個(gè)參數(shù)帶有默認(rèn)值的函數(shù)實(shí)例分析
這篇文章主要介紹了php定義一個(gè)參數(shù)帶有默認(rèn)值的函數(shù),實(shí)例分析了php參數(shù)帶有默認(rèn)值的函數(shù)使用技巧,需要的朋友可以參考下2015-03-03ajax 的post方法實(shí)例(帶循環(huán))
在最近的項(xiàng)目中,為了能解決在大數(shù)據(jù)查詢中出現(xiàn)的超時(shí)問題,需要將大數(shù)據(jù)拆分成小數(shù)據(jù),然后進(jìn)行循環(huán)處理。本人經(jīng)驗(yàn)不足,技術(shù)有限,只能想到用ajax來傳送數(shù)據(jù)。2011-07-07什么是OneThink oneThink后臺(tái)添加插件步驟
這篇文章主要為大家詳細(xì)介紹了oneThink后臺(tái)添加插件的具體實(shí)現(xiàn)步驟,內(nèi)容簡(jiǎn)單,步驟完整,感興趣的小伙伴們可以參考一下2016-04-04PHP根據(jù)傳來的16進(jìn)制顏色代碼自動(dòng)改變背景顏色
根據(jù)傳來的16進(jìn)制顏色代碼自動(dòng)改變背景顏色,需要的朋友可以參考下2014-06-06php 數(shù)組動(dòng)態(tài)添加實(shí)現(xiàn)代碼(最土團(tuán)購系統(tǒng)的價(jià)格排序)
最近在實(shí)現(xiàn)最土團(tuán)購系統(tǒng)的價(jià)格排序功能,需要對(duì)$oc數(shù)組進(jìn)行擴(kuò)展,經(jīng)過測(cè)試用下面的方法即可。2011-12-12