合肥生活安徽新聞合肥交通合肥房產生活服務合肥教育合肥招聘合肥旅游文化藝術合肥美食合肥地圖合肥社保合肥醫院企業服務合肥法律

        COMP2404代做、C++編程設計
        COMP2404代做、C++編程設計

        時間:2024-11-04  來源:合肥網hfw.cc  作者:hfw.cc 我要糾錯



        COMP2404 -“Introduction to Software Engineering”
        Assignment 3
        1 Submission Instructions
        Submit to Brightspace on or before the due date a compressed file (.tar or .zip) that includes
        1. Header and source files for all classes instructed below.
        2. A working Makefile that compiles and links all code into a single executable. The Makefile should be specific
        to this assignment - do not use a generic Makefile.
        3. A README file with your name, student number, a list of all files and a brief description of their purpose,
        compilation and execution instructions, and any additional details you feel are relevant.
        2 Learning Outcomes
        In this assignment you will learn to
        1. Add functionality to an existing codebase.
        2. Change a class implementation while keeping the same interface
        3. Make a UML diagram to illustrate the interaction between classes.
        4. Implement copy constructors that use deep copy, while properly managing all dynamic memory.
        5. Implement proper encapsulation (using the const keyword where appropriate)
        VERY IMPORTANT!!! YOU WILL LOSE MARKS IF YOU DO NOT CONST YOUR FUNC TIONS AND PARAMETERS!!!.
        3 Overview
        This is a continuation of the GetHub project from assignment 2. As a starting point, you may use your own assignment,
        or use the code provided.
        In addition to changing existing classes, you will implement a Client class that can “download” (i.e., make a
        deep copy of) a Repo, and then print the Files it contains.
        As before there is a Control class that connects and coordinates the functionality of your classes with a View
        class. In addition there is a separate TestControl class that allows you to run tests.
        You will be required to make a UML diagram of the completed project.
        4 UML Diagram
        Make a UML diagram of the completed project. You may omit the Control, TestControl, Tester, and View classes.
        A partial UML diagram is provided to help you get started. It includes the “uses” notation, which we did not discuss
        in class, but this is the only place in the diagram where this particular notation should appear.
        COMP2404 -“Introduction to Software Engineering”
        Assignment 3
        GetHub
        // add, remove, get
        + addRepo(in title: string, in owner: string)
        + deleteRepo(in index: int)
        + getNumRepos(): int
        + download(in index: int, out repo: Repo): bool
        + addFile(in repo: string, in title: string, in content: string, in date: Date)
        + addFile(in repo: int, in title: string, in content: string, in date: Date)
        + deleteFile(in repo: int, in file: int)
        // print
        + printRepos()
        + printRepo(in index: int)
        + printFileContents(in repoIndex: int, in fileIndex: int)
        Client
        + cloneRepo(in getHub: GetHub, in index: int)
        + printRepo ( )
        + printFileContents(in index: int)
        uses
        COMP2404 -“Introduction to Software Engineering”
        Assignment 3
        5 Classes Overview
        This application will consist of 11 classes. Ten classes are provided: these are the same classes from Assignment 2.
        You will add another class and make changes to some of the existing classes.
        1. The Date class (Entity object):
        (a) Contains date information.
        2. The File class (Entity object):
        (a) Contains information about the File (name, content, last date modified)
        3. The Repo class (Entity object):
        (a) Contains information about the Repo (title, owner)
        (b) Manages a collection of Files
        4. The FileList class (Collection object):
        (a) Data structure for File pointers.
        5. The RepoList class (Collection object):
        (a) Data structure for Repo pointers.
        6. The GetHub class (Control, Collection, View object):
        (a) Manages a collection of Repos.
        (b) Provides services to add, delete, access, and print Repos and the Files in the Repos.
        (c) Prints (error) messages to std::cout
        7. The View class (Boundary object):
        (a) Presents a menu, takes input from the user
        8. The Control class (Control object):
        (a) Manages the interaction of the other objects.
        9. The TestControl class (Control object):
        (a) Manages the interaction of the other objects in order to run tests.
        10. The Tester class (???):
        (a) Provides testing functionality.
        We will be using std::cout as the main output object for error reporting.
        COMP2404 -“Introduction to Software Engineering”
        Assignment 3
        6 Instructions
        Download the starting code from Brightspace. It includes some global functions that you are to use for testing as
        well as some classes. All member variables are private unless otherwise noted. All member functions are public
        unless otherwise noted. Some return values are not explicitly given. You should use your best judgment (they will
        often be void, but not always). ALL CLASSES MUST HAVE A PRINT FUNCTION (except for FileList and
        RepoList). This print function should display the metadata of the class using appropriate formatting.
        Your finished code should compile into two executables called a3 and a3test using the command make all or
        simply make. The Makefile is provided for you. Your submission should consist of a single zip file with a suitable
        name (e.g., assignment2.zip) that contains a folder containing all your files. This folder should also contain a
        README with your name, student number, a list of all files that are included, a directory structure (if applicable),
        compiling and running instructions, and any other information that will make the TAs life easier when they mark
        your assignment.
        Below are the changes you should make to the existing project. Section 6.1 should be applied to all classes.
        6.1 Encapsulation
        You should apply the const keyword to existing classes wherever possible. That means any function that can be made
        const should be, and any parameter that can be made const should be. The only exceptions are (Test)Control,
        Tester, and View classes - you do not need to apply const to these classes.
        VERY IMPORTANT!!! YOU WILL LOSE MARKS IF YOU DO NOT CONST YOUR FUNC TIONS AND PARAMETERS!!!.
        6.2 The File Class
        We are going to modify the lessThan function, and add an equals function.
        1. Adjust the lessThan() function so that it returns true if this File’s name comes before the parameter’s name
        in alphabetical order. If the two names are equal (i.e., it is the same File) then order them as defined by
        Date::lessThan using the lastModified parameter.
        2. Make an equals() function that returns true if the name and the Date are equal (you do not have to compare
        the content).
        6.3 The Repo Class
        You should add a copy constructor to the Repo class that does a deep copy of all data. Be sure to add any other
        functions that you require, here or in other classes, to correctly manage your memory.
        6.4 The List Classes
        Modify FileList and RepoList so that they are both implemented using DOUBLY LINKED LISTS. You should
        keep the same interface (public functions defined in the header), and the functions should do the same jobs as before
        (except for isFull, detailed below).
        Observe that once you change the implementation, everything should work exactly as before. That means all
        the tests will pass whether you change these classes or not. But a TA will check and deduct or award marks as
        appropriate. There is an additional change detail below.
        1. FileList and RepoList:
        (a) Have isFull() always return false.
        COMP2404 -“Introduction to Software Engineering”
        Assignment 3
        (b) As a reminder, FileList should add Files in the order defined by File::lessThan, while RepoList
        should add Repos to the back of the list.
        6.5 The Client Class
        Make a Client class. Refer to the UML diagram for function specifications. As in the GetHub class, when an
        operation fails, be sure to send an appropriate error message to cout.
        1. Member variables:
        (a) A Repo pointer. This is the current Repo that the Client is working with.
        2. The constructor should initialize all member variables appropriately (you should set your pointer to nullptr
        to start with).
        3. The destructor should delete all dynamically allocated memory reachable by this class.
        4. cloneRepo: cloneRepo should make a deep copy of the GetHub Repo at the given index, and store the address
        in your Repo pointer.
        5. printRepo: call Repo::printFiles on the stored Repo, or give an error message if the Repo pointer is null.
        6. printFileContents(int index): Call printContents on the File stored at the given index.
        6.6 The Control Class
        This class controls the interactions between the View, GetHub, and Client classes. Most of it has been done for you.
        You should add a Client class, and complete downloadRepo(), printClientRepo() and printClientFileContent().
        6.7 The TestControl Class
        This class has been done for you. It interacts with your classes and the View to run a series of tests and output your
        mark.
        The old tests are provided for convenience. They may not work properly until you const your classes. You get
        5 marks if the old tests still work after you have made your modifications.
        In addition there are 2 new tests for the Client class worth 10 marks each.
        6.8 The View Class
        This class has been done for you. It interacts with the user and returns values to the control object
        6.9 The main.cc and test.cc Files
        These have been done for you. main.cc is compiled into an executable a3 using the Control class. test.cc is
        compiled into an executable a3test using the TestControl and Tester classes. The a3 executable lets you interact
        with your application from a user’s perspective. The a3test executable runs tests and gives you your mark.
        7 Grading
        The marks are divided into three main categories. The first two categories, Requirements and Constraints are
        where marks are earned. The third category, Deductions is where you are penalized marks.
        COMP2404 -“Introduction to Software Engineering”
        Assignment 3
        7.1 Specification Requirements
        These are marks for having a working application (even when not implemented according to the specification, within
        reason). The test suite will automatically allocate the marks, though they can be adjusted by the marking TA if
        some anomaly is found.
        General Requirements
        • All marking components must be called and execute successfully to earn marks.
        • All data handled must be printed to the screen to earn marks (make sure the various print functions print
        useful information).
        Application Requirements: With the exception of the memory leaks marks (Part 6), these marks are generated
        by the a3test executable. Part 5 will be tested by a TA by running the individual tests in the a3test executable
        with valgrind.
        1. (5 marks):
        (a) RepoList test
        (b) GetHub Repo test
        (c) GetHub File test
        2. (10 marks): Client cloneRepo test
        3. (10 marks): Client memory test
        4. (10 marks, 5 marks each) FileList and RepoList are Doubly Linked Lists.
        5. (4 marks): Tests 2 and 3 should pass with no memory leaks or other memory faults (2 marks per test)
        6. (6 marks total) Control functions
        (a) (2 marks) downloadRepo
        (b) (2 marks) printClientRepo
        (c) (2 marks) printClientFileContent
        7. (5 marks) UML diagram
        Requirements Total: 50 marks
        7.2 Constraints
        The previous section awards marks if your program works correctly. In this section marks are awarded if your
        program is written according to the specification and using proper object oriented programming techniques. This
        includes but is not limited to:
        • Apply “const”-ness to your program.
        – Print statements, getters, and any member function that does not change the value of any member variables
        should be const.
        – Any parameter object (passed by reference) that will not be modified should be const.
        • Proper declaration of member variables (correct type, naming conventions, etc).
        COMP2404 -“Introduction to Software Engineering”
        Assignment 3
        • Proper instantiation of member variables (statically or dynamically)
        • Proper instantiation of objects (statically or dynamically)
        • Proper constructor and function signatures.
        • Proper constructor and function implementation.
        • Proper use of arrays and data structures.
        • Passing objects by reference or by pointer. Do not pass by value.
        • Reusing existing functions wherever possible within reason. There are times where duplicating tiny amounts
        of code makes for better efficiency.
        • Proper error checking - check array bounds, data in the correct range, etc.
        7.2.1 Constraints: 10 marks
        1. 2 marks: Proper implementation and const-ing of the File class.
        2. 2 marks: Proper implementation and const-ing of the List classes.
        3. 2 marks: Proper implementation and const-ing of the Repo class.
        4. 2 marks: Proper implementation and const-ing of the GetHub class.
        5. 2 marks: Proper implementation and const-ing of the Client class.
        Constraints Total: 10 marks
        Requirements Total: 50 marks
        Assignment Total: 60 marks
        7.3 Deductions
        The requirements listed here represent possible deductions from your assignment total. In addition to the constraints
        listed in the specification, these are global level constraints that you must observe. For example, you may only use
        approved libraries, and your programming environment must be properly configured to be compatible with the virtual
        machine. This is not a comprehensive list. Any requirement specified during class but not listed here must also be
        observed.
        7.3.1 Documentation and Style
        1. Up to 10%: Improper indentation or other neglected programming conventions.
        2. Up to 10%: Code that is disorganized and/or difficult to follow (use comments when necessary).
        COMP2404 -“Introduction to Software Engineering”
        Assignment 3
        7.3.2 Packaging and file errors:
        1. 5%: Missing README
        2. 10%: Missing Makefile (assuming this is a simple fix, otherwise see 4 or 5).
        3. up to 10%: Failure to use proper file structure (separate header and source files for example), but your program
        still compiles and runs
        4. up to 50%: Failure to use proper file structure (such as case-sensitive files and/or Makefile instructions) that
        results in program not compiling, but is fixable by a TA using reasonable effort.
        5. up to 100%: Failure to use proper file structure or other problems that severely compromise the ability to
        compile and run your program.
        As an example, submitting Windows C++ code and Makefile that is not compatible with the Linux VM would
        fall under 4 or 5 depending on whether a reasonable effort could get it running.
        7.3.3 Incorrect object-oriented programming techniques:
        • Up to 10%: Substituting C functions where C++ functions exist (e.g. don’t use printf or scanf, do use cout
        and cin).
        • Up to 25%: Using smart pointers.
        • Up to 25%: Using global functions or global variables other than the main function and those functions and
        variables expressly permitted or provided for initialization and testing purposes.
        7.3.4 Unapproved libraries:
        • Up to 100%: The code must compile and execute in the default course VM provided. It must NOT require
        any additional libraries, packages, or software besides what is available in the standard VM.
        • Up to 100%: Your program must not use any classes, containers, or algorithms from the standard template
        library (STL) unless expressly permitted.

        請加QQ:99515681  郵箱:99515681@qq.com   WX:codinghelp



         

        掃一掃在手機打開當前頁
      1. 上一篇:ME5701程序代寫、代做Matlab設計編程
      2. 下一篇:CS 7280代做、代寫Python編程語言
      3. 無相關信息
        合肥生活資訊

        合肥圖文信息
        出評 開團工具
        出評 開團工具
        挖掘機濾芯提升發動機性能
        挖掘機濾芯提升發動機性能
        戴納斯帝壁掛爐全國售后服務電話24小時官網400(全國服務熱線)
        戴納斯帝壁掛爐全國售后服務電話24小時官網
        菲斯曼壁掛爐全國統一400售后維修服務電話24小時服務熱線
        菲斯曼壁掛爐全國統一400售后維修服務電話2
        美的熱水器售后服務技術咨詢電話全國24小時客服熱線
        美的熱水器售后服務技術咨詢電話全國24小時
        海信羅馬假日洗衣機亮相AWE  復古美學與現代科技完美結合
        海信羅馬假日洗衣機亮相AWE 復古美學與現代
        合肥機場巴士4號線
        合肥機場巴士4號線
        合肥機場巴士3號線
        合肥機場巴士3號線
      4. 上海廠房出租 短信驗證碼 酒店vi設計

        主站蜘蛛池模板: 国产在线精品一区二区夜色| 欧美成人aaa片一区国产精品 | 国产成人高清视频一区二区| 久久久综合亚洲色一区二区三区| 麻豆va一区二区三区久久浪| 久久久精品人妻一区亚美研究所| 一区二区三区福利视频| 亚洲AV无码一区二区一二区| 日韩精品一区二区三区中文| 久久精品无码一区二区三区日韩| 日韩在线一区视频| 国产高清在线精品一区| 国产一区二区三区乱码| 免费无码一区二区三区蜜桃| 一区二区三区四区精品| 精品一区二区三区影院在线午夜 | 中文字幕乱码亚洲精品一区| 久久中文字幕一区二区| 亲子乱av一区二区三区| 成人区人妻精品一区二区不卡视频| 国产精品无码一区二区三区免费 | 无码一区二区三区| 国产综合一区二区| 国产精品特级毛片一区二区三区| 福利一区二区视频| 国产伦一区二区三区免费| 无码福利一区二区三区| 78成人精品电影在线播放日韩精品电影一区亚洲 | 一区二区网站在线观看| 亚州国产AV一区二区三区伊在| 美女视频一区二区| 亚洲AV日韩精品一区二区三区| 一区二区三区四区在线播放| 一区二区网站在线观看| 亚洲成人一区二区| 久久免费国产精品一区二区| 亚洲码一区二区三区| 精品国产一区二区三区麻豆| 亚洲av乱码一区二区三区按摩| 国模无码一区二区三区| 一区二区三区高清在线|