哈工大軟體構造Lab2(2022)

来源:https://www.cnblogs.com/kalesky/archive/2022/05/30/16327501.html
-Advertisement-
Play Games

哈爾濱工業大學2022春軟體構造Lab2實驗經歷與實驗心得,可供後來學子借鑒學習 ...


(防扒小助手)

本人CSDN博客:

https://blog.csdn.net/m0_61753302https://blog.csdn.net/m0_61753302本人博客園博客(同步CSDN):

https://www.cnblogs.com/kalesky/https://www.cnblogs.com/kalesky/如果對你有用的話歡迎點贊關註喲!

 

目錄

 

1、實驗目標概述

2、實驗環境配置

3、實驗過程

3.1 Poetic Walks

3.1.1 Get the code and prepare Git repository

3.1.2 Problem 1: Test Graph

3.1.3 Problem 2: Implement Graph

3.1.4 Problem 3: Implement generic Graph

3.1.5 Problem 4: Poetic walks

​​​​​​​3.1.6  Before you’re done

3.2 ​​​​​​​ Re-implement the Social Network in Lab1

​​​​​​​3.2.1 FriendshipGraph類

​​​​​​​3.2.2  Person類

​​​​​​​3.2.3  客戶端main()

3.2.4 測試用例 

3.2.5 提交至Git倉庫

4 實驗進度記錄

5 實驗過程中遇到的困難與解決途徑

6 實驗過程中收穫的經驗、教訓、感想

6.1 實驗過程中收穫的經驗和教訓

6.2 針對以下方面的感受


 

1、實驗目標概述

本次實驗訓練抽象數據類型(ADT)的設計、規約、測試,並使用面向對象

編程(OOP)技術實現 ADT。具體來說:

  1.  針對給定的應用問題,從問題描述中識別所需的 ADT
  2.  設計 ADT 規約(pre-conditionpost-condition)並評估規約的質量;
  3.  根據 ADT 的規約設計測試用例;
  4.  ADT 的泛型化;
  5.  根據規約設計 ADT 的多種不同的實現;針對每種實現,設計其表示 (representation)、表示不變性(rep invariant)、抽象過程(abstraction function)
  6.  使用 OOP 實現 ADT,並判定表示不變性是否違反、各實現是否存在表示泄露(rep exposure)
  7.  測試 ADT 的實現並評估測試的覆蓋度;
  8.  使用 ADT 及其實現,為應用問題開發程式;
  9.  在測試代碼中,能夠寫出 testing strategy 並據此設計測試用例。

 

2、實驗環境配置

(1)安裝測試用例代碼覆蓋度插件

經過網上查閱資料瞭解到,在IDEA中已經集成了代碼覆蓋度插件JaCoCo,切換方式如下:

編輯

 

點擊Edit Configuration,彈出如下視窗:

編輯

 在Code Coverage一欄點擊Modify勾選紅框中的選項,則會彈出切換代碼覆蓋度工具的選項:

編輯

 通過咨詢軟體構造課程老師與助教老師,瞭解到使用IDEA自帶的代碼覆蓋度工具即可,不需要切換到JaCoCo,因此下文代碼覆蓋度測試均使用IDEA自帶的coverage runner進行測試。

 

 

2、GitHub Lab2倉庫的URL地址(Lab2-學號)

略。 

 

 3、實驗過程

3.1 Poetic Walks

該任務主要是通過實現一個圖的模塊來練習ADT的規約設計和ADT的不同實現。

(1)完善Graph介面類,並運用泛型的思想,將String拓展為泛型L類;

(2)實現Graph介面類:以邊和點兩種方式實現介面;

(3)利用實現的Graph類,應用圖的思想,實現GraphPoet類。如果輸入的文本的兩個單詞之間存在橋接詞,則插入該橋接詞;若存在多個單一橋接詞,則選取邊權重較大者。

 

3.1.1 Get the code and prepare Git repository

從要求文件中對應網址下載得到實驗代碼,建立好project,進入目錄,打開Git bush

依次輸入:

git init

git remote add origin [email protected]:ComputerScienceHIT/HIT-Lab2-120L022408.git

git pull origin master

git add .

git commit -m “init”

git push origin master

 

 

 

3.1.2 Problem 1: Test Graph <String>

測試Graph的靜態方法。

為了方便測試Graph的多種實現,在 GraphInstanceTest 中測試了實例方法。

編寫測試用例主要利用等價類劃分的思想進行測試,測試策略如下:

編輯

 分別編寫覆蓋以上條件的測試用例。

 

運行GraphStaticTest得到測試結果如下:

編輯

 

3.1.3 Problem 2: Implement Graph <String>

3.1.3.1 Implement ConcreteEdgesGraph

(1)Edge類實現

定義兩個private String類型的變數source和target存放每個邊的起止點

定義一個private int類型的變數weight保存這條邊的權重(長度)

private final String source, target;

private final int weight;

關於AF,RI和rep exposure:

編輯

① 構造器 constructor

構造方法,使用上述三個數據域聲明一個新的邊

public Edge(L source_new, L target_new, int weight_new)
{
    this.source = source_new;
    this.target = target_new;
    this.weight = weight_new;
    checkRep();
}

② 檢查表示不變數 checkRep

檢查表示不變數,其中source和target必須非空,weight必須大於0

public void checkRep()
{
    assert source != null;
    assert target != null;
    assert weight > 0;
}

③ get方法

get_Source:返回source域

get_Target:返回target域

get_Weight:返回weight域

④ toString方法

返回一個字元串表明這條邊是從哪個source到哪個target,其weight是多少。

public String toString()
{
    return source.toString() + "->" + target.toString() + "\t權重為" + weight + '\n';
}

 

(2)ConcreteEdgesGraph實現

vertices和edges分別記錄當前graph所含有的點和邊

private final Set<String> vertices = new HashSet<>();
private final List<Edge<String>> edges = new ArrayList<>();

關於AF,RI和rep exposure:

 

編輯

 ① add方法

public boolean add(String vertex)

如果頂點不為空,添加一個頂點。如果在vertices的Set集合中成功添加了vertex,則返回true。

② Set方法

public int set(String source, String target, int weight)

輸入source,target,weight,確定一條有向邊。

具體做法:如weight!=0,移去可能已經存在的相同起始點的邊,然後加入新的邊,如weight=0,尋找可能已經存在的相同起始點的邊,刪去。

③ remove方法

public boolean remove(String vertex)

從vertices中刪去給定的vertex點,遍歷edges,尋找該vertex是否為某條邊的起點或者終點,刪去相應的邊。在使用迭代器遍歷時要使用iterator.remove方法保證安全性。

④ vertices方法

public Set<String> vertices()

返回vertices集合。註意做到safety from rep exposure ,使用Collections.unmodifiableSet()方法。

編輯

⑤ sources方法

public Map<String, Integer> sources(String target)

參數:target。根據傳入的target參數尋找以targe為終點的邊。返回一個鍵值對為(點,權重)的map。

實現:建立一個map,利用迭代器遍歷edges,如果某個edge的edge.get_Target()和傳入參數target相等,則將該邊的source和weight存入map中。

⑥ targets方法

public Map<String, Integer> targets(String source)

參數:source。根據傳入的source參數尋找以source為起點的邊。返回一個鍵值對為(點,權重)的map。

實現:建立一個map,利用迭代器遍歷edges,如果某個edge的edge.get_Source()和傳入參數source相等,則將該邊的target和weight存入map中。

⑦ 檢查表示不變數 checkRep

思路:n個點,最多構成n*(n-1)條有向邊,因此存在這種不可變的數學關係

⑧ toString方法

對每條邊調用toString方法,整合起來。

public String toString()
{
    String s = "";
    for (Edge<L> e : edges)
    {
        s = s + e.toString();
    }
    return s;
}

 

(3)ConcreteEdgesGraphTest測試

JUnit測試結果如下:

編輯

 

 試覆蓋率:

 

編輯

 

 3.1.3.2 Implement ConcreteVerticesGraph

(1)Vertex類實現

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

-Advertisement-
Play Games
更多相關文章
  • mysqldump 和 mydumper 是我們常用的兩個邏輯備份工具。 無論是 mysqldump 還是 mydumper 都是將備份數據通過 INSERT 的方式寫入到備份文件中。 恢復時,myloader( mydumper 中的恢復工具 ) 是多線程導入,且一個 INSERT 語句中包含多條 ...
  • 不同行業的開發者對地圖樣式的展示需求差異很大。例如,物流類應用希望地圖樣式簡潔一些,重點突出城市分佈和快遞路徑;AR游戲類應用中的地圖色彩需要和游戲UI適配,做的更酷炫一些;景區導覽應用中的地圖樣式要景區特色相結合,重點呈現關鍵景點。 自定義地圖樣式可以更好的迎合不同行業的開發者對於地圖樣式的展示需 ...
  • 5月24日, HUAWEI Developer Day(簡稱HDD)線上沙龍·創新開發專場活動成功舉辦。HMS Core機器學習服務(ML Kit)產品經理在會上圍繞機器翻譯的技術優勢、使用場景和接入指導等為開發者們做了詳細解讀。ML Kit將助力開發者更快更好地開發翻譯類應用,幫助用戶輕鬆跨越語種 ...
  • 本章是系列文章的第五章,介紹了指針分析方法。指針分析在C/C++語言中非常重要,分析的結果可以有效提升指針的優化效率。 本文中的所有內容來自學習DCC888的學習筆記或者自己理解的整理,如需轉載請註明出處。周榮華@燧原科技 5.1 概念 指針是許多重要編程語言的特性之一 指針的使用,可以避免大量的數 ...
  • 在開始進行實驗之前,我已經新建了一個空目錄/data,並將該目錄掛載了一塊新硬碟,將硬碟分區格式化為ext4的格式,所以當我操作/data目錄下的文件及文件夾的時候,實際上就是針對新掛載的硬碟進行數據讀寫操作。首先通過下麵的命令準備一下實驗用的文件,新建一個文件/data/delfile1.txt並 ...
  • J對avaSE_多線程入門 線程安全 死鎖 狀態 通訊 線程池進行簡要總結和介紹 ...
  • 目錄 一.簡介 二.效果演示 三.源碼下載 四.猜你喜歡 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 轉場 零基礎 O ...
  • 一個工作了7年的粉絲,他說在面試之前,Spring這塊的內容準備得很充分。 而且各種面試題也刷了,結果在面試的時候,面試官問:”說說你對Spring MVC的理解“。 這個問題一下給他整不會了,就是那種突然不知道怎麼組織語言,最後因為回答比較混亂沒通過面試。 ok,對於這個問題,我們來看看普通人和高 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...