OO第一次總結作業

来源:https://www.cnblogs.com/h87d/archive/2019/03/27/10608481.html
-Advertisement-
Play Games

第一次OO博客作業 前言 面向對象課程已經經過了4周的時間。前三次作業全部是關於多項式求導的相關內容,內容由易到難,同時我也開始逐漸深入感受學習面向對象的各項特征,逐漸將自己的編程風格從C向真正的面向對象語言轉換。同時我還接觸了DEBUG和互測屋這樣嶄新的學習方式,在閱讀別人代碼的過程中不斷增強自己 ...


第一次OO博客作業

前言

   面向對象課程已經經過了4周的時間。前三次作業全部是關於多項式求導的相關內容,內容由易到難,同時我也開始逐漸深入感受學習面向對象的各項特征,逐漸將自己的編程風格從C向真正的面向對象語言轉換。同時我還接觸了DEBUG和互測屋這樣嶄新的學習方式,在閱讀別人代碼的過程中不斷增強自己的編程能力和學習能力。

本篇博客將結合3次作業內容,分別從題目的理解思路,代碼風格和度量,BUG的產生以及修複和Applying Creational Pattern共4個方面分析我這四周以來的工作。

一、第一次多項式求導作業

第一次作業相對之後的2次簡單許多,但是由於是第一次運用JAVA編寫這樣有一定規模的程式,對我還是有一定挑戰的。

我將第一次作業大致分為3個階段,包括多項式的格式檢查,多項式的求導以及最後的化簡輸出。在第一步的格式檢查中先檢查空格部分,再將空格刪除,用一長條正則匹配所有字元。在求導部分對每一項進行匹配,共有5種格式可能,分別對這5種情況進行求導,同時將結果存入HASHMAP中,最終在最後的化簡輸出函數中對指數相同部分,以及0,1進行化簡,最終輸出。

         以下為第一次作業的類圖:

   相信這應該是我所寫過的最面向過程的JAVA程式,整個程式自始至終只有一個類,並且整個程式的結構類似於C程式那樣流水線的順序結構,將所有函數以及數據都封裝在同一個類里。這直接導致了在第二次作業的無法擴展,只能推倒重來。

第一次作業BUG分析

在第一次作業我的程式在測試中總共檢出過2個BUG,分別為正則爆棧以及邏輯判斷式中的計算順序問題。

         首先是正則爆棧問題。在第一次作業中由於第一次使用正則表達式,沒有採取分段匹配的方法,而是對整段統一一起匹配,如下圖所示。

 

由於在第一次寫正則表達式時使用貪婪匹配,直接導致程式爆棧。在DEBUG中將其改為獨占模式進行匹配,得以解決問題,但在風格上無疑是很不好的。因此在後2次作業中進行了逐項匹配。

第二個BUG屬於比較低級的錯誤

 

  問題出現在mlj2中,在BUG修複前沒有括弧,而判斷目的是先進行或運算再進行與運算,與預設運算順序不同,導致格式判斷出現錯誤。

總結

總體第一次作業難度不高,但由於是第一次編寫有一定規模的JAVA程式,在程式風格,重構考慮以及細節等很多地方都沒有做到位,也算是給自己長了一次教訓。

 

 

二、第二次多項式求導作業

第二次作業相對於第一次作業增加了sin(x)和cos(x)求導,相對於第一次作業需要增加對於sin(x)和cos(x)的正則識別,同時在求導規則和化簡上增加了一定的難度。總體上格式判斷與第一次求導作業相同,但了可能的三個運算符與數字的組合,需要在第一次求導格式判斷的基礎上增加一個新的判斷函數。在最終結果方面,將每一項變為a*x^b*sin(x)^c*cos(x)^d的形式,併在最後根據情況進行化簡。

以下為第二次作業的類圖:

 

 

  在第二次作業中我首先將整個多項式作為一個Poly類,對其進行空格檢查。在刪除空格後通過加減號進行劃分,將整個多項式分解為各個獨立的項,在對每項進行格式檢查後進行求導,將求導形成的 abcd4元組變換成字元串存入Arraylist中。最後將繫數項相同的部分以及1和0進行化簡,最後輸出結果。復用了第一次作業的空格判斷函數,但在函數求導上與第一有較大差別。第一次作業使用HASHMAP進行儲存,而這一次使用ARRAYLIST,於是只能大規模重寫。

  總體代碼風格上較第一次有比較大的改善。我總共建立了2個類:多項式類和項類,在多項式類中進行空格和符號的格式檢查,以及最後的化簡輸出工作。在項類中進行每一項的格式檢查以及求導工作。但在細節等很多方面都有可以增加的地方,例如使用介面進行規範。同時我也沒有讓項類繼承多項式類的部分特性,而是重覆編寫了許多相同功能的函數。以及在格式檢查傳遞錯誤信息中我使用了變數傳遞,雖然在原理上可行,但是是不被推崇的編程方法,因此在第三次作業中通過拋出錯誤的方法替代了該部分的方法。

第二次求導作業中的BUG:

         第二次作業在結構上並沒有BUG出現,但在細節上出現了BUG。在對1進行化簡時沒有考慮項內只有1的情況,導致將為1的項整個消去了,產生錯誤。這也提醒我在編寫這樣有一定代碼量的程式時不但要註重總體的思路和結構,還要小心這樣的細節之處。同時在DEBUG時要充分考慮各種情況。正是由於這樣的一個小錯誤使我直接掉入C檔,算是吃一塹長一智吧。

 

 

 

三、第三次多項式求導作業

         第三次作業相對第二次作業增加了多項式的嵌套情況,在求導上複雜度增加,無法只通過4元組的形式表示所有的求導結果。同時在格式判斷,項切割等各個方面增加了難度,需要考慮括弧等各種新的因素。程式類圖如下所示:

 

 

我的程式將可能出項的結構情況大致歸為3類,包括多項式類(Poly)、項類(MPoly)和因數類(Subpoly)。在多項式類中我大致進行了3項工作,包括多項式的空格以及符號檢查,對多項式中項的劃分以及將項的求導結果進行整合,形成多項式的求導結果。在項類中我大致進行2項工作,對項進行分割形成因數,同時將因數求導結果進行整合,形成項的求導結果。在因數類中進行2項工作,包括對因數格式的檢查以及對因數的求導。在這3類之外為了方便區分系統EXCEPTION以及格式錯誤2種情況引起的WRONG FORMAT!,我定義了一個自定義異常DException.

由於第二次作業考慮對於擴展的需求,在這一次作業中我成功復用了第二次作業所有格式判斷函數以及部分求導函數。但這一次作業在細節上仍然有很多不足之處。我的思想仍然沒有徹底擺脫C的限制,在第二次作業中同樣沒有使用類的繼承以及介面等JAVA特性的功能。同時可以從類圖中看到,我不必要的屬性以及類內部分方法的複雜度仍然過高,這都是我在接下來亟需轉變的問題。如果仍然將自己的思想局限於面向過程中我勢必會遇到瓶頸和障礙。

第三次作業BUG:

在第三次作業中由於個人能力和時間有限並沒有對整個多項式進行化簡工作,因此相比前2次作業在化簡時的BUG,我這一成功通過了所有強測案例。同時為了避免不必要BUG的出現,我在另一方面增加了最終表達式的複雜性,方法是將所有的+轉變為+1*,負號轉化為-1*,但卻忘記考慮了一種特殊情況,即將 sin(-23)轉變為sin(-1*23),導致了互測時BUG的出現。這也提示我在編程時要從實際出發,如果一直使用這樣的小聰明必定會導致意外出現。

第三次作業總結

         在第三次作業中我成功實現了對前2次作業的擴展,通過遞歸以及進一步的劃分類的方法實現了嵌套求導。但在類繼承、介面實現這些JAVA特性結構的使用上仍然有很大的不足之處,同時並沒有實現最終的化簡工作。

四、關於互測屋和DEBUG

         我對別人的DEBUG方法相對而言分為2步。第一步即在自己編寫程式的過程中將可能出現的BUG記下來,然後在互測時攻擊別人,其中主要包括格式錯誤以及可能出現的爆棧錯誤。例如空串,1,1-1,0*x^0等這樣的常見錯誤。通常這種方法特別有效,將近70%的錯誤都可以通過這樣的方法解決。第二步就是閱讀他人的代碼。由於要閱讀將近7個人的代碼,沒有時間一行一行讀,我採取的做法是挑選重點讀,通常是匹配的正則表達式,求導過程以及最終的化簡步驟等幾個場景愛你犯錯誤的地方。通過這2步的配合90%的錯誤都能被找到。

在3個星期的互測中,通過閱讀他人的代碼我也開拓了眼界,學到了不少東西。包括工廠函數,以及優秀正則表達式書寫等各項新的知識。同時也促使我充分反省自己糟糕的代碼風格。

五、Applying Creational Pattern

         由於使用JAVA仍然不夠熟練,在3次作業中我都沒有充分考慮到重構的問題。三次作業的求導過程都截然不同,全部重寫。但格式判斷函數,即對空格以及加減號合法性判斷得到了復用。

六、總結

    經過了3個星期的多項式編程,我初步掌握了JAVA的編程方法和麵向對象的基本思想,目前仍有2項不足之處,首先我的思想仍然很大程度上收到C的限制,總是想通過面向過程的方法解決問題。第二是對JAVA語言的部分特性不太熟悉,當別人介面,繼承,工廠函數非常熟練時,我仍然在把JAVA當C寫,使用多個函數定義想解決一切問題,這顯然是不合適的。在接下來的學習和編程中我需要充分認識到自己的不足,從他人的代碼,網上以及課堂上充分學習,使自己成為一個合格的JAVA程式員。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 微服務這幾年不可謂不火,很多技術團隊都開始在自己的項目上引入了微服務。一方面這些團隊確實很好的推動了微服務的應用和發展,另一方面也可以看到一些盲目追技術熱點的行為所帶來的危害,比如很多中小團隊對微服務的基礎知識只是做了很淺顯的瞭解就開始盲目的推動微服務的實施,最後導致了項目的失敗。 微服務要想做好是 ...
  • 學習一樣東西,我們首先要知道為什麼要學這個,或者說這個東西能起到什麼作用。這樣才能更加有目的、有效率地進行學習。 然後再問為什麼這個東西能實現這樣的效果,從而瞭解其內部的機制。 最後,再弄清楚怎麼使用,這樣才算真正學會了。 換而言之,把要學習的技能比喻成實現某一功能的函數,那麼瞭解函數的功能、函數的 ...
  • 一.自我代碼分析 1.度量: 第一次作業: 第二三次作業(改動很小,給出第三次作業結果): 2.總體自我評價: 第一次作業代碼實現糟糕,可以從代碼統計結果看到這一點,第二三次感覺比較滿意,思路順暢方法簡單可擴展性強但面向對象思想還不夠(甚至沒有繼承和介面),倒算是比較精緻的面向過程,不過類的高內聚低 ...
  • 一、作業結構分析 第一次作業: 類圖(真·一類到底) 方法複雜度、類複雜度、類間依賴 第二次作業: 類圖 方法複雜度、類複雜度、類間依賴 第三次作業: 類圖 方法複雜度、類複雜度、類間依賴 結果一目瞭然:方法複雜度、類複雜度逐漸減少;類間依賴程度增加、類的層級化更加明顯。 應用工具度量得到的結果和我 ...
  • 深層理解-棧平衡原理-底層是如何實現棧平衡的? 在iOS、android操作系統中,經常會遇到入棧出棧的操作。 那麼現在操作系統已經不需要我們去關心堆棧的操作。 比如:iOS中的ARC模式,android中的JVM都會幫我們自動釋放記憶體,自動保持堆棧平衡。但是對於開發者來說,還是很有必要掌握堆棧平衡 ...
  • 對於一個的坐擁1.4億多用戶,平均日活躍用戶量超過 3400 萬,人均日訪問時長 1 小時,月累計頁面訪問量達到 230 億的大廠來說(數據截止2018年 3 月),知乎的AI都到底應用在了哪些領域,這中間應用到了哪些技術和模型,又產生了哪些作用?今日第1期數智方法論將從內容生產、內容消費與分發、內... ...
  • 那個時候初入java這個大家庭,學習的方向很亂。畢業後,在公司磨練了一年,總想著是該交一份答卷了,可能成績不會很好,但求及格!那麼考試題目呢,我計劃搭建一個橫向可擴展的項目,可以在平臺自擴展各種子項目,包括 後臺許可權控制,日誌分析,秒殺,微信小程式,愛代客(www.idaike.com)項目等等,所 ...
  • OO第一單元作業總結 在第一單元作業中,我們只做了一件事情:求導,對多項式求導,對帶三角函數的表達式求導,對有括弧嵌套的表達式求導。作業難度依次遞增,讓我們熟悉面向對象編程方法,開始從面向過程向面向對象轉變。本文中,我將介紹我個人每一次作業的做法,以及三次作業的分析,互測時策略。 第一次作業 第一次 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...