国产人妻人伦精品_欧美一区二区三区图_亚洲欧洲久久_日韩美女av在线免费观看

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

代寫159.251編程、代做Java程序語言

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


 

159.251 - Software Design and Construction

Assignment 2 (22%)

Deadlines

You must submit your final work using the stream submission system no later than Sunday 19

November 2023. The penalty is 10% deducted from the total possible mark for every day delay

in submission (one day late – out of **%, two days late then out of 80% … etc.).

You are expected to manage your source code, this includes making frequent backups. It is

strongly recommended (but not required) to use a private git repository for this assignment,

and commit as frequently as possible. “The Cat Ate My Source Code” is not a valid excuse for a

late submission.

How to submit

1. Upload a zip file consisting of:

a. The Maven project folder (inc. pom.xml)

b. performance-analysis.pdf -measure time and memory consumption

c. coverage.pdf/html - the pdf or html version of the coverage report created by

Maven

2. upload this file to stream - note: the max upload size is set to 20 MB

3. verify the submission: download the zip file, unzip it into a new folder and inspect

content, run Maven from the command line, check the output including generated jar

files

Task

Work individually to create the following program in Java.

Create a project assign251_2 using the Maven project layout, and within this project, create a

project that implements custom appender and layout objects for Log4j. For this, you will need to

create an appender and layout that work with the other Log4j objects (i.e. implementing

relevant Log4j abstract classes or interfaces), test them and run profiling tools on them to gauge

their correctness and efficiency.

Note, there is no main class for this project, it will be run via your tests from sections 3 and 4.

You may want to consider a test-driven development methodology, where your first step is to

start with section 3 and work backwards. This will allow you to check that your classes are

working correctly as you go.

1. Implement a log4j appender - assign251_2.MemAppender [7 marks]

In this task, you will need to implement a custom log4j appender, which can be used directly

with the log4j logger. This MemAppender, unlike normal appenders, stores logs in memory and

prints them on demand. There is a limit to how many log events will be kept in memory (this

should be configurable), and if the maximum is reached, the oldest logs should be deleted.

Implementation details:

- It enforces the singleton pattern.

- It stores the LoggingEvents in a list. This is supplied by dependency injection (note: if

you have already created a default, that is okay).

- It will need a layout. This will need to be able to be supplied when the instance of an

MemAppender is obtained, and via the setLayout() method. If a layout is not supplied,

and code calling it is needed, appropriate precondition checks should be used (as some

code may not use the appender with the layout, so it is a valid option not to supply one,

as long as you don’t use any functionality that requires it).

- There are three ways to get information about the LoggingEvents that it stores:

a. Call the method getCurrentLogs() which will return an unmodifiable list of the

LoggingEvents.

b. Call the method getEventStrings() which will return an unmodifiable list of

strings (generated using a layout stored in the MemAppender).

c. Call the method printLogs() which will print the logging events to the console

using the layout and then clear the logs from its memory.

- It has a property called maxSize, which needs to be configurable. When this size is

reached, the oldest logs should be removed to make space for the new ones.

- The number of discarded logs should be tracked, and can be accessed using

getDiscardedLogCount(). This should be stored as a long type, as there may be many

discarded logs.

Note: Be careful to observe the DRY principle - there are overlapping requirements above.

3.5 marks Correct implementation of the singleton pattern and dependency injection

options for the list and layout.

2 marks Correct implementation of the information printing / collection methods,

along with sensible precondition checks where appropriate.

1.5 mark Correct implementation of maxSize and associated features.

2. Implement a layout - assign251_2.VelocityLayout [3

marks]

a. VelocityLayout basically works like PatternLayout, but uses Velocity as the

template engine. This layout should work with log4j appenders as well as the

MemAppender.

b. Variable to be supported:

i. c (category)

ii. d (date using the default toString() representation)

iii. m (message)

iv. p (priority)

v. t (thread)

vi. n (line separator)

c. This means that the variable syntax is different, e.g. use $m instead of %m

d. VelocityLayout should have options to set its pattern both in the constructor and

via a setter. An example string pattern could look like:

“[$p] $c $d: $m”

3. Write tests that test your appender and layout in combination with different loggers,

levels and appenders [4 marks]

a. Use JUnit for testing your appender and layout. Aim for good test coverage and

precise asserts.

b. Use the tests to show both the appender and layout working with different

combinations of built-in log4j classes as well as with each other.

c. Tests should be stored in the appropriate locations according to the Maven folder

structure.

4. Write tests to stress-test your appender/layout by creating a large amount of log

statements [6 marks]

a. Create a separate test class for stress tests.

b. Use these tests to compare the performance between MemAppender using a

LinkedList, MemAppender using an ArrayList, ConsoleAppender and

FileAppender - measure time and memory consumption (using JConsole,

VisualVM or any profiler)

c. Consider how to output your logs in such a way that makes comparisons

between the MemAppender and other appenders sensible.

d. Use these scripts to compare the performance between PatternLayout and

VelocityLayout

e. Stress tests should test performance before and after maxSize has been

reached, and with different maxSize values.

i. parameterised tests may be helpful here.

f. Write a short report summarising your findings (embed screenshots of memory

usage charts in this report taken from VisualVM). The report name should be

performance-analysis.pdf

g. Measure your test coverage of the written tests by generating branch and

statement coverage reports using Jacoco or Emma. Submit this report with your

project (should be placed under ~/target/ folder”

Note that the marks for this section will be based on your reporting, the effectiveness of your

stress tests in probing into the efficiency of the classes, and the overall integration testing,

checking that these classes work in combination with other relevant out-of-the-box classes.

5. Write a Maven build script [2 marks]

a. The Maven script should be used to build the project including compiling, testing,

measuring test coverage, and dependency analysis. All dependencies should be

managed with your maven build.

b. Use the jacoco Maven plugin for measuring test coverage.

Hints

● You can use any development environment you prefer, as it is a Maven project.

● Library approved list: only the following libraries can be used: Apache log4j, Apache

Velocity, JUnit 5, Google Guava, Apache Commons Collections, JaCoCo (for code

coverage).

Penalties

1. Code that is not self-documenting, or long or complex methods.

2. Violating the Maven standard project layout or Java naming conventions.

3. Use of absolute paths (e.g., libraries should not be referenced using absolute paths like

“C:\\Users\\..”, instead use relative references w.r.t. the project root folder)

4. References to local libraries (libraries should be referenced via the Maven repository)

5. Use of libraries not on the whitelist

Bonus Question [2 marks]

You can get 100% for the assignment without this. This will give you additional marks up to the

maximum if you lose some elsewhere.

Create an MBean object for each instance of the MemAppender to add JMX monitoring to this

object, the properties to be monitored are

1. the log messages as array

2. the estimated size of the cached logs (total characters)

3. the number of logs that have been discarded

Marking Rubric

Your assessment will be based on the following criteria:

Criteria Mark

Implementation of log4j appender assign251_2.MemAppender 7

Correct implementation of the singleton pattern and dependency injection

options for the list and layout.

3.5

Correct implementation of the information printing / collection methods,

along with sensible precondition checks where appropriate

2

Correct implementation of maxSize and associated features. 1.5

Implementation of layout assign251_2.VelocityLayout 3

Correct use of the Velocity template engine 1

Works with appenders and MemAppender 1

Supports listed variables 1

Testing the implemented appender and layout 4

Use of Junit with good coverage and precise asserts 2

Tests show that the appender and layout work with different combinations of

built-in log4j classes and each other

1.5

Tests stored in appropriate locations following Maven directory structure 0.5

Stress-testing your appender/layout 6

Separate class for stress tests 0.5

Comparison of performance between MemAppender using LinkedList,

ArrayList, ConsoleAppender and FileAppender - with measurements: time,

memory consumption for different maxSizes

2

Scripts to compare velocity and pattern layout 1

Report of stress test findings with an analysis of the stress test results and

measurements

2

Test coverage reports 0.5

Build management 2

Uses maven for dependency, coverage (using jacoco) 2

(extra/bonus)

Implementation of an MBean object for instances of MemAppender for JMX

monitoring of properties: log messages, estimated size of cached logs,

number of logs discarded

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

 

掃一掃在手機打開當前頁
  • 上一篇:代做指標定制選股公式代寫通達信山峰心理線副圖
  • 下一篇:GTSC2093代做、Java/Python編程代寫
  • 無相關信息
    合肥生活資訊

    合肥圖文信息
    流體仿真外包多少錢_專業CFD分析代做_友商科技CAE仿真
    流體仿真外包多少錢_專業CFD分析代做_友商科
    CAE仿真分析代做公司 CFD流體仿真服務 管路流場仿真外包
    CAE仿真分析代做公司 CFD流體仿真服務 管路
    流體CFD仿真分析_代做咨詢服務_Fluent 仿真技術服務
    流體CFD仿真分析_代做咨詢服務_Fluent 仿真
    結構仿真分析服務_CAE代做咨詢外包_剛強度疲勞振動
    結構仿真分析服務_CAE代做咨詢外包_剛強度疲
    流體cfd仿真分析服務 7類仿真分析代做服務40個行業
    流體cfd仿真分析服務 7類仿真分析代做服務4
    超全面的拼多多電商運營技巧,多多開團助手,多多出評軟件徽y1698861
    超全面的拼多多電商運營技巧,多多開團助手
    CAE有限元仿真分析團隊,2026仿真代做咨詢服務平臺
    CAE有限元仿真分析團隊,2026仿真代做咨詢服
    釘釘簽到打卡位置修改神器,2026怎么修改定位在范圍內
    釘釘簽到打卡位置修改神器,2026怎么修改定
  • 短信驗證碼 寵物飼養 十大衛浴品牌排行 suno 豆包網頁版入口 目錄網 排行網

    關于我們 | 打賞支持 | 廣告服務 | 聯系我們 | 網站地圖 | 免責聲明 | 幫助中心 | 友情鏈接 |

    Copyright © 2025 hfw.cc Inc. All Rights Reserved. 合肥網 版權所有
    ICP備06013414號-3 公安備 42010502001045

    国产人妻人伦精品_欧美一区二区三区图_亚洲欧洲久久_日韩美女av在线免费观看
    日韩中文理论片| 日韩av不卡在线| 91精品国产高清自在线看超| 国产日本欧美在线| 国产一区喷水| 国产欧美日韩一区二区三区| 国产女精品视频网站免费| 国产日韩换脸av一区在线观看| 国内精品模特av私拍在线观看| 欧美激情www| 好吊色欧美一区二区三区| 激情五月六月婷婷| 欧美怡春院一区二区三区| 青青在线免费视频| 免费久久久久久| 国产伦精品一区二区三区免| 99电影在线观看| 久久婷婷人人澡人人喊人人爽| 国产成人综合久久| 日韩中文娱乐网| 国产精品区一区二区三在线播放| 久久久91精品国产一区不卡| 国产精品免费观看久久| 精品国偷自产一区二区三区| 国产999在线| 一区二区三区精品国产| 亚洲人成无码www久久久| 一本色道久久综合亚洲二区三区| 一级特黄录像免费播放全99| 亚洲高清123| 日韩男女性生活视频| 国内精品久久久久久影视8| 国产欧美日韩综合一区在线观看| wwwwww欧美| 久久99精品久久久久久青青日本| 久久久国产精品一区| 精品国产乱码久久久久久久软件 | 日韩一区二区av| 国产精品区一区二区三含羞草| 国产精品久久久精品| 一区二区三区电影| 日本一本草久p| 黄瓜视频免费观看在线观看www| 国产乱子伦精品无码专区| 久久亚洲精品欧美| 国产精品久久91| 天天好比中文综合网| 国内自拍欧美激情| 国产精品av在线| 国产精品美女久久久久av福利| 九九精品视频在线| 熟女少妇精品一区二区| 国内精品模特av私拍在线观看| 国产男女在线观看| 日韩中文字幕免费| 欧美精品www在线观看| 日韩一级免费看| 国产日韩欧美视频| 久久久久久久久久国产| 亚洲尤物视频网| 韩日欧美一区二区| 国产极品粉嫩福利姬萌白酱| 操日韩av在线电影| 人妻熟女一二三区夜夜爱| 国产精品一二三在线观看| 国产精品日韩欧美一区二区三区| 亚洲一区二区不卡视频| 欧美大香线蕉线伊人久久国产精品| 国产精品永久免费视频| 久久精品国产2020观看福利| 午夜精品一区二区三区av| 国产色综合一区二区三区| 久久久久欧美| 日韩在线观看a| 97欧洲一区二区精品免费| 国产精品免费区二区三区观看| 亚洲福利av在线| 国产女同一区二区| 国产精品日韩欧美大师| 日韩av在线第一页| 国产精品午夜国产小视频| 国产精品电影久久久久电影网| 欧美一区二区三区免费观看| 成人久久一区二区三区| 麻豆成人在线看| 国产在线精品一区免费香蕉| 久久九九免费视频| 欧美在线一区二区三区四区| 久久伊人资源站| 亚洲国产一区二区在线| 国产精品一国产精品最新章节| 欧美伦理91i| 国内精品久久久久久| 日韩在线视频播放| 日韩视频第二页| 国产a级片免费看| 日韩av不卡电影| av天堂永久资源网| 日产国产精品精品a∨| 久久精品国产美女| 欧美中文字幕精品| 国产精品免费久久久久影院| 精品一区二区日本| 欧美成人亚洲成人日韩成人| 国产玖玖精品视频| 一区二区在线高清视频| 国产精品99久久久久久大便| 日韩欧美一区三区| 国产精品男人爽免费视频1| 国产日韩欧美日韩| 亚洲欧洲日韩精品| 久久久久中文字幕2018| 日本a级片在线观看| 日韩视频永久免费观看| 免费国产黄色网址| 在线观看成人av| 久久免费视频1| 国自在线精品视频| 中文字幕一区二区三区四区五区| 91精品国产沙发| 日韩精品无码一区二区三区| 国产精品美女主播在线观看纯欲| 国产日本欧美在线观看| 亚洲一区二区三区精品视频| 久久本道综合色狠狠五月| 免费在线精品视频| 亚洲综合精品伊人久久| 久久久www免费人成黑人精品| 欧美日韩一道本| 亚洲欧洲一区二区在线观看| 色妞在线综合亚洲欧美| 国产欧美韩日| 全黄性性激高免费视频| 久99九色视频在线观看| 国产传媒久久久| 国产一级做a爰片久久毛片男| 亚洲精品在线视频观看| 视频一区视频二区国产精品 | 欧美激情在线一区| 99久久自偷自偷国产精品不卡| 日本韩国在线不卡| 美女扒开尿口让男人操亚洲视频网站| 久久综合久久久久| 国产在线资源一区| 日本精品视频在线| 精品国产乱码久久久久| 国产www免费| 国产欧美精品一区二区三区| 日本a级片在线播放| 欧美激情在线观看视频| 色偷偷偷亚洲综合网另类| 成人免费无码av| 好吊色欧美一区二区三区视频 | 色乱码一区二区三区熟女| 国产精品久久国产精品99gif| 91精品国产综合久久香蕉的用户体验 | 欧美高清中文字幕| 川上优av一区二区线观看| 国产精品日韩一区二区三区| 久久久久国产精品视频| 成人欧美一区二区三区黑人| 精品日本一区二区三区在线观看| 亚洲 欧美 综合 另类 中字| 蜜月aⅴ免费一区二区三区| 久久精品国产99国产精品澳门| 国产精品69久久| 国产精自产拍久久久久久| 欧美一二三视频| 日本一本a高清免费不卡| 欧美极品第一页| 国产精品视频不卡| 久久久久久久免费| 国产av无码专区亚洲精品| 91久热免费在线视频| 国产日产亚洲精品| 精品少妇一区二区三区在线| 欧美日韩在线播放一区二区| 日本亚洲欧洲色α| 岛国视频一区| 中文字幕一区二区三区精彩视频 | 色婷婷av一区二区三区久久| 国产成人在线亚洲欧美| 91精品久久久久久久久久久久久久 | 久久成年人视频| 国产精品久久久av久久久| 国产精品无码人妻一区二区在线 | 国产精品97在线| 91精品网站| 国产极品尤物在线| 国产精品 欧美在线| 97色在线播放视频| 成人国产精品一区| 91免费看国产| 91精品成人久久| 久久久www免费人成黑人精品| 久久综合给合久久狠狠色 | 国产精品无码人妻一区二区在线| 久久视频中文字幕| 国产精品日韩高清| 国产精品二区三区|