91精品国产91久久久久久_国产精品二区一区二区aⅴ污介绍_一本久久a久久精品vr综合_亚洲视频一区二区三区

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

代寫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編程代寫
  • 無相關信息
    合肥生活資訊

    合肥圖文信息
    2025年10月份更新拼多多改銷助手小象助手多多出評軟件
    2025年10月份更新拼多多改銷助手小象助手多
    有限元分析 CAE仿真分析服務-企業/產品研發/客戶要求/設計優化
    有限元分析 CAE仿真分析服務-企業/產品研發
    急尋熱仿真分析?代做熱仿真服務+熱設計優化
    急尋熱仿真分析?代做熱仿真服務+熱設計優化
    出評 開團工具
    出評 開團工具
    挖掘機濾芯提升發動機性能
    挖掘機濾芯提升發動機性能
    海信羅馬假日洗衣機亮相AWE  復古美學與現代科技完美結合
    海信羅馬假日洗衣機亮相AWE 復古美學與現代
    合肥機場巴士4號線
    合肥機場巴士4號線
    合肥機場巴士3號線
    合肥機場巴士3號線
  • 短信驗證碼 目錄網 排行網

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

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

    91精品国产91久久久久久_国产精品二区一区二区aⅴ污介绍_一本久久a久久精品vr综合_亚洲视频一区二区三区
    久久综合精品国产一区二区三区| 蜜臀av性久久久久蜜臀av麻豆| 亚洲精品视频在线观看免费| 日日夜夜一区二区| 岛国一区二区在线观看| 一区三区视频| 欧美系列在线观看| 久久久久99精品一区| 亚洲制服丝袜av| 国产毛片精品视频| 亚洲久久在线| 日韩一区二区三区免费观看| 亚洲欧美电影院| 精品一区二区影视| 在线看片欧美| 日韩精品一区二区三区视频在线观看 | 一本色道久久综合狠狠躁的推荐| 日韩欧美中文一区| 亚洲国产精品精华液网站| 丁香亚洲综合激情啪啪综合| 亚洲欧美日韩国产一区| 精品处破学生在线二十三| 午夜免费久久看| 韩日视频一区| 日韩一区二区三区四区五区六区 | 午夜一区二区三视频在线观看| 精品va天堂亚洲国产| 日韩精品五月天| 激情婷婷久久| 精品少妇一区二区三区日产乱码| 日韩vs国产vs欧美| 亚洲大胆视频| 久久久久久久久免费| 九九国产精品视频| 欧美综合77777色婷婷| 国产精品美女久久久久aⅴ| 国产精品亚洲а∨天堂免在线| 免费在线亚洲| 亚洲人成网站色在线观看| 91视频一区二区三区| 欧美高清视频www夜色资源网| 亚洲18影院在线观看| 伊人精品视频| 国产日韩欧美在线一区| 风间由美一区二区av101| 91传媒视频在线播放| 亚洲欧美日韩成人高清在线一区| 欧美在线首页| 欧美精品一区二区三区蜜桃视频| 国产一区三区三区| 欧美色涩在线第一页| 视频一区在线播放| 国产精品视频福利| 亚洲最大成人综合| 亚洲美女91| 亚洲欧美日韩国产手机在线 | 亚洲欧洲综合另类| 国产精品yjizz| 国产精品无人区| 欧美高清日韩| 国产目拍亚洲精品99久久精品 | 日本一区二区三级电影在线观看 | 国产精品家庭影院| 欧美日韩久久| 国产精品久久久久一区 | 亚洲在线视频网站| 国产精品美女诱惑| 亚洲一区二区三区三| 国产精品毛片一区二区三区| 亚洲一区影音先锋| 免费日韩一区二区| 日本三级韩国三级欧美三级| 色综合久久66| 美腿丝袜亚洲色图| 欧美巨大另类极品videosbest | 亚洲一区影院| 日韩精品1区2区3区| 欧美午夜精品一区二区蜜桃| 久久精品国产一区二区| 欧美精品日韩精品| 国产91高潮流白浆在线麻豆| www精品美女久久久tv| 欧美在线一二三区| 国产精品久久久一本精品| 国产亚洲成人一区| 美日韩黄色大片| 欧美一区二区福利在线| 91色.com| 一区二区三区日韩精品| 久久久久久亚洲精品杨幂换脸 | 欧美性猛交一区二区三区精品| 国产在线精品一区二区三区不卡| 欧美一级精品大片| 欧美在线视频二区| 亚洲一区二区三区四区在线| 欧美亚洲国产bt| 成人18精品视频| 亚洲免费观看在线视频| 欧美在线高清视频| 不卡的av电影| 亚洲精品国产精华液| 欧美午夜片在线观看| 91网站最新地址| 亚洲国产精品人人做人人爽| 91麻豆精品国产91久久久资源速度 | 欧美高清一区| 视频在线观看一区| 精品国产乱码91久久久久久网站| 亚洲国产高清一区二区三区| 日本不卡1234视频| 久久色在线观看| 亚洲制服av| 成人黄色av网站在线| 亚洲男女一区二区三区| 欧美视频在线不卡| 欧美福利在线| 久久综合综合久久综合| 国产欧美精品一区| 日本精品一区二区三区高清| 欧美fxxxxxx另类| 日本欧美在线看| 亚洲国产精品精华液2区45| 一本大道久久a久久综合婷婷 | 亚洲国产精品高清| 欧美丝袜丝nylons| 在线欧美亚洲| 国产91精品免费| 亚洲成人久久影院| 国产亚洲精品福利| 欧美视频日韩视频在线观看| 国模精品一区二区三区| 国产高清久久久| 亚洲高清久久久| 久久精品一区二区三区不卡| 欧美性视频一区二区三区| 亚洲精美视频| 成人18视频在线播放| 日韩精品一二三四| 亚洲素人一区二区| 精品久久久久久综合日本欧美| 香蕉久久a毛片| 欧美日韩一区二区三区在线观看免 | 欧美视频二区| 国产69精品久久久久777| 午夜精品福利一区二区蜜股av | 在线精品一区二区| 91免费视频观看| 国产精品综合网| 日韩高清欧美激情| 亚洲欧美另类小说| 国产日本欧美一区二区| 日韩一区二区三区视频在线 | 蜜臀精品久久久久久蜜臀 | 色婷婷久久综合| 中国成人亚色综合网站| 欧美激情四色| 99在线精品免费| 国产馆精品极品| 久久99精品久久久久久| 午夜欧美2019年伦理| 一区二区视频在线| 国产精品久久久久久久久图文区| 日韩欧美的一区二区| 欧美视频中文一区二区三区在线观看| 国产伦精品一区二区三区四区免费| 牛夜精品久久久久久久99黑人| 国产suv精品一区二区6| 国产一区日韩二区欧美三区| 久草这里只有精品视频| 久久精品免费看| 九九视频精品免费| 精品一区二区日韩| 国模娜娜一区二区三区| 麻豆精品在线播放| 奇米777欧美一区二区| 日韩和欧美一区二区| 亚洲成a人片在线观看中文| 亚洲高清视频中文字幕| 午夜精品aaa| 人人超碰91尤物精品国产| 免费观看久久久4p| 狠狠网亚洲精品| 国产精品一区二区男女羞羞无遮挡 | 亚洲激情啪啪| 国产精品亚洲综合| 国产伦精品一区二区三区视频黑人 | 精品国产免费久久| 国产无人区一区二区三区| 国产欧美精品一区二区色综合 | 精品动漫av| 亚洲综合视频一区| 在线这里只有精品| 欧美精品在线一区二区三区| 日韩欧美高清dvd碟片| 久久久久国产一区二区三区四区| 欧美国产日韩在线观看| 亚洲女爱视频在线| 日韩精品一区第一页| 国产精品一区二区三区四区| 97久久久精品综合88久久|