|
|
||
|---|---|---|
| .. | ||
| testdata | ||
| .sync | ||
| README.md | ||
| go.mod | ||
| go.sum | ||
| stats.go | ||
| stats_optimization_test.go | ||
| stats_test.go | ||
README.md
Домашнее задание №10 «Оптимизация программы»
Вам дан исходный код функции GetDomainStat(r io.Reader, domain string), которая:
- читает построчно из
rпользовательские данные вида
{"Id":1,"Name":"Howard Mendoza","Username":"0Oliver","Email":"aliquid_qui_ea@Browsedrive.gov","Phone":"6-866-899-36-79","Password":"InAQJvsq","Address":"Blackbird Place 25"}
{"Id":2,"Name":"Brian Olson","Username":"non_quia_id","Email":"FrancesEllis@Quinu.edu","Phone":"237-75-34","Password":"cmEPhX8","Address":"Butterfield Junction 74"}
{"Id":3,"Name":"Justin Oliver Jr. Sr.","Username":"oPerez","Email":"MelissaGutierrez@Twinte.gov","Phone":"106-05-18","Password":"f00GKr9i","Address":"Oak Valley Lane 19"}
(осторожно, в отличие от конкретной строки файл целиком не является валидным JSON);
- подсчитывает количество email-доменов пользователей на основе домена первого уровня
domain.
Например, для данных, представленных выше:
GetDomainStat(r, "com") // {}
GetDomainStat(r, "gov") // {"browsedrive": 1, "twinte": 1}
GetDomainStat(r, "edu") // {"quinu": 1}
Для большего понимания см. исходный код и тесты.
Необходимо оптимизировать программу таким образом, чтобы она проходила все тесты.
Нельзя:
- изменять сигнатуру функции
GetDomainStat; - удалять или изменять существующие юнит-тесты.
Можно:
- писать любой новый необходимый код;
- удалять имеющийся лишний код (кроме функции
GetDomainStat); - использовать сторонние библиотеки по ускорению анмаршалинга JSON;
- добавлять юнит-тесты.
Обратите внимание на запуск TestGetDomainStat_Time_And_Memory
go test -v -count=1 -timeout=30s -tags bench .
Здесь используется билд-тэг bench, чтобы отделить обычные тесты от тестов производительности.
Оформление пул-риквеста
В идеале к подобным пул-риквестам пишут бенчмарки и прикладывают результаты работы benchstat, чтобы сразу было видно, что стало лучше и насколько.
Критерии оценки
- Пайплайн зелёный и нет попытки «обмануть» систему - 4 балла
- Добавлены юнит-тесты - до 3 баллов
- Понятность и чистота кода - до 3 баллов
Частые ошибки
- Работа с сырыми байтами, нахождение позиции
"Email"и пр. вместо ускорения анмаршалинга более поддерживаемыми и понятными средствами.