OO第二次blog作業
前言
這三次的作業可以分為兩個階段,前一個階段是上三次作業“答題判題程式”的進一步迭代,而後一部分則是另一道題目“家居強電電路模擬程式”。
從結果來看,電路模擬程式的完成不盡人意,尤其是第二次迭代的電路模擬,由於這次沒有了測試點的提示,導致程式在提交出現錯誤後不知從何處下手進行修改。這也是個慘痛的教訓,在真正的現實情況下,肯定是不會有測試點提示的。日後要爭取在設計階段進行最佳化,提前考慮好可能出現的各種情況,彌補這次的失誤。
後續將對近三次作業進行一些具體的分析。
三次作業分析
第一次作業
第一次作業是對上次答題判題程式的進一步迭代。在此次迭代中,題目加入了多選題和填空題的型別,並且輸入順序方面也進行了改動。只要是正確型別的資料便可以任意順序輸入。除此之外還引入了多張試卷的情況,按照學生學號和試卷號對輸出進行排序。
由於引入了兩種新的題目型別,採用繼承的方法來定義三種不同的題目類。
Stone類作為題庫,其中儲存一個連結串列,包含所有輸入題目的資訊。後續刪除的行為也是對此處進行操作。
Respond類、Paper類和Student類分別用於儲存答卷、試卷和學生資訊。
GetMassage類用於對輸入的資訊進行判別、處理以及相應的儲存。
Judge類作為代理類,用於對學生的答卷進行判斷並輸出相應的資料。
SourceMonitor分析結果如下
![image]
由於在是上一次的程式碼上進行了改進,在修正了一些錯誤的同時也延續了程式碼的一些問題,比如採用多重分支語句等,導致程式碼的深度和複雜度仍舊居高不下。
第二次作業
第二次作業出現了新的題型——“家居強電電路模擬程式”,這次的題型模擬包括了三種控制裝置和三種受控裝置。
由於是第一次迭代,模擬情況僅包含了單條串聯電路。
定義了兩個父類控制類和用電器類,三種控制裝置類受控裝置類分別繼承自這兩個父類。
還定義了一個Ponit類啊作為代理類,用於輸入資訊、對輸入資訊進行處理和輸出資訊。
SourceMonitor分析結果如下
從圖中可以看出,程式碼的深度和平均複雜度較低,但最大複雜度過高,這是由於在Point類中當處理輸入資訊時使用了多重分支語句和多重迴圈所導致的。
第三次作業
第三次作業是前一次作業的迭代,在這次作業中,加入了並聯電路的情況和一種新的用電器落地扇。
這次作業的難度無疑是又上了一個臺階,不僅僅是設計的難度提高了,而且沒有給出測試點也是給我們出了一個難題。
由於上一次的程式碼難以對並聯電路的輸入進行處理,因此本次迭代對程式碼進行了重構。
相較於上次程式碼,本次程式碼構建了Skewer類和Combine類分別為串聯電路類和並聯電路類。
此次程式碼還構建了一個最高階父類Machine類,並聯電路類、控制類和用電器類都繼承自這個類。Machine類的構建使得我能夠在定義串聯電路類時使用一個連結串列來儲存資訊。
SourceMonitor分析結果如下
從圖中可以看出,經過本次程式碼的重構,程式碼的複雜度有了顯著的下降,這主要是由於定義了串聯電路類與並聯電路類的原因。並且Machine類的使用使得在串聯電路中對資料的呼叫和計算複雜度更低。
下面進行對三次作業的歷程進行一些詳細的描述與心得分享。
歷程
第一次作業
這是在本次程式碼修改後的第一次提交,本次提交修改了資訊的輸入和處理,實現了資訊的亂序輸入,但對於多份答卷的問題還未得到解決。同時本份程式碼也存在其他問題,會使得出現分零返回的情況。
此次修改更正了資訊的呼叫部分,解決了陣列越界所引起的非零返回問題。但是對於多張試卷的問問題仍未得到解決。
在試卷類中加入了用於處理多張試卷的屬性後,多張試卷的問題得到了解決,但仍有少數測試點存在問題。但在後續修改了某些會出現問題的情況後也得到了解決。
第二次作業
這是本次程式碼的首次提交情況,由於但由於分檔調節器的部分問題導致有些測試點出現錯誤,在修正後便解決。
在與同學的交流中,我得知了最後三個測試點的情況是在用電器的兩端都有一個開關,但由於我本次程式碼的設計問題,它只能處理一個控制元件和一個用電器的情況,所以導致沒有透過這三個測試點。這個問題直到下一次大作業中才得到解決。
第三次作業
在我看來這次作業相較於上次的難度提高了不少,在首次提交時我只拿到了三分,並且還出現了非零返回的情況。在對程式碼的檢查後發現時在對串聯電路資訊進行儲存後在呼叫時沒有及時更新導致呼叫的資料錯誤或是不存在在導致的。
在對資訊輸入進行了少許的修改後,又多過了幾個測試點,並且也解決了非零返回的問題。
對計算裝置資料時如何呼叫串聯電路資料庫中的資料部分進行修改,又正確了一部分,但由於沒有測試點的提示,導致不知道下一步應該對何處進行最佳化。
總結
在設計方面還需具有前瞻性,要考慮到對後續功能新增的情況,否則每次對程式碼進行迭代時都需要進大量的重構,耗費大量的時間不說,還可能會出現很多bug。
此外,最後一次作業沒有給出測試點,因此導致自己不知從何處進行下一步的最佳化。然而在現實案例中,是不可能像這樣給出一個個測試點的。因此,自身尋找錯誤的能力也需要加強。