本文分析講述了PHP程式碼維護,重構變困難的4種原因。分享給大家供大家參考,具體如下:
程式碼維護,重構是件很令人不爽的一件事。以下幾種情況,會讓程式碼維護和重構變得很困難。
1. 專案開始時,大家規定好一些程式碼規範,在一定的規範下進行開發,但是人的思想是不一樣的,也就是說每個功能不同的人實現的邏輯可能會有這樣那樣的不同,導致了一些人不願意去看別人代碼,要改別人代碼,首先要了解這個人當時是怎麼想的,他的邏輯是怎麼樣的。所以有很多人的想法是有那看別人代碼的時間,我就重新做好了。這種想法不要有,看別人程式碼也能學到不少東西。如果都這樣想,我想冗餘程式碼會越來越多,後期重構會變的越來越困難。
2. 做程序的一般跳槽都比較頻繁,專案開始的時候,是5個人(專案創辦人)開發的,等專案上線了,可能有人離職了。人手不夠,公司招募。專案創辦人呢,對新招的人,不太信認,怕修改原代碼會導致上線的功能出問題,所以就出了新規定,最好不要修改上線過的程序,如果需求變動,最好重新寫class或是function,這樣的話,程式碼會變的越來越多。可能會出現幾個class都差不多,或是多個function的功能差不多。
3. 資料庫冗餘字段,冗餘表過多,也會讓程式碼維護變的十分困難。因為功能優化,或新需求,導致原有表結構根本不能滿足新需求,這個時候,就會去表裡添加字段,或者掛接另一個表,長期以往,數據庫變的很臃腫,數據庫一大,程式碼肯定就不用說了,程式都是圍繞著資料來的,冗餘字段,冗餘表都要維護的,不然資料就不統一了。必要的冗餘可以減少資料庫查詢,如果過多,只會事得其返。所以在修改資料庫時更要考慮清楚,考慮未來資料庫和程式碼要重構的情況。
4. 個人原因是最主要的原因,首先要有分塊思想,也可以說是oop思想,這種思想是在實戰中養成的,這個是要一定時間的。不要為了急著去實現功能而忽略了整體考慮。假如來了一個新需要,我會先考慮怎麼實現這個需求,有了思路後,我也不會急著去開發這個功能,我還會在考慮這個功能模組,會不會用在其他地方?如果其他地方用,怎麼樣讓其他地方用著更方便。我會讓所以呼叫這個功能模組的地方,介面只有一個。然後我才會著手去開發。還有一點,不要相信需求定下來就不會改變了,不會的。人的想法很多,開發程式碼的時候,這點也要考慮進去,所以統一的介面在需求變動時,我只要修改一個地方,其他地方都可以改掉。如果這樣考慮了,前期開發時,時間會多一點,但是後期維護就快很多。
小結一下,有了上面4點,重構資料庫,重構程式碼將是必然的
1. 人的思想不可能一樣,大家都在盡量往一處想,但是總會有這樣,那樣的不同。
2. 急於完成功能,而不深入了解別人程式碼。研究別人程式碼不如重新開發快,這種想法不好。
3. 資料庫冗餘,這個我個人覺得必然會出現的,一個專案做大,做強,一定是在不斷的成長,成長過程中,資料庫不可能是一成不變的。
4. 缺少分塊思想,我覺得一個項目,就是很多功能獨立的小塊通過一定線串起來的,代碼重構也就是把這些小塊的重新組合,當然各個小塊,在重構前後實現的功能會不一樣,但它還是為了實現一定的功能,只不過由舊變新而已。
上面的幾點是我在開發專案過程中實際遇到的,歡迎大家補充。
更多關於PHP相關內容有興趣的讀者可查看本站專題:《PHP基本語法入門教程》、《php物件導向程式設計入門教學》及《php優秀開發框架總結》
希望本文所述對大家PHP程式設計有幫助。
以上就介紹了PHP程式碼維護,重構變困難的4種原因分析,包含了方面的內容,希望對PHP教學有興趣的朋友有幫助。