Форум программистов, компьютерный форум, киберфорум
Наши страницы

C# для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Outwork
4 / 4 / 0
Регистрация: 05.08.2014
Сообщений: 54
#1

.NET 4.x Прошу консультации экспертов (ООП, многопоточность) - C#

16.11.2016, 13:02. Просмотров 2181. Ответов 45

Здравствуйте уважаемые форумчане! Давеча пытался устроиться на работу и прислали мне тестовое задание, далее привожу его текст:
Требуется написать консольную программу на C# для генерации сигнатуры указанного файла. Сигнатура генерируется следующим образом: исходный файл делится на блоки заданной длины (кроме последнего блока), для каждого блока вычисляется значение hash-функции SHA256, и вместе с его номером выводится в консоль.
Программа должна уметь обрабатывать файлы, размер которых превышает объем оперативной памяти, и при этом максимально эффективно использовать вычислительные мощности многопроцессорной системы. При работе с потоками допускается использовать только стандартные классы и библиотеки из .Net 3.5 (исключая ThreadPool, BackgroundWorker, TPL). Ожидается реализация с использованием Thread-ов. Путь до входного файла и размер блока задаются в командной строке. В случае возникновения ошибки во время выполнения программы ее текст и StackTrace необходимо вывести в консоль.
В общем посидел пару вечеров и наваял прогу на сколько позволяли знания и навыки. Поскольку ранее ничего подобного не делал, поначалу даже показалось, что задание несложное. Однако отправляя проект не оставляло ощущение, что сделал не так как надо.
Так в итоге и оказалось. Мне вежливо отказали дополнив комментариями касательно кода:
1. Вся программа в одном файле, двух классах и нескольких статических методах. ООП нет.
Классы не являются лишними, если у них есть понятная область отвественности.
В данном случае, если бы выделили класс для запуска потоков и отслеживания их завершения – то это не было бы лишним.

2.Алгоритм работы не эффективный. Файл сразу бьется на блоки и для каждого блока стартует новый поток. Все сразу. Никого thread pool нет.
Для подсчета хэша каждого блока запускается отдельный поток. Запуск потока трудоемкая операция, которая требует много ресурсов. Вариантов решения этой проблемы возможно несколько. Или реализовывать свою вариацию threadPool или использовать долгоживущие потоки.
Кроме того, сейчас никак не ограничивается число запущенных потоков. При их большом количестве, они будут бороться за процессорное время и значительная часть ресурсов будет тратиться на переключение контекстов между потоками.

3.Ожидание окончания всех потоков на Thread.Sleep
Ожидание завершения на Thread.Sleep является ресурсоемким. Поскольку основной поток, ждущий завершения, постоянно просыпается и занимает процессорное время, которое можно было потратить на обсчет следующего блока. Для решения этих проблем используют примитивы синхронизации.
Проверка окончания всех потоков происходит на статической перемерной threadCount. К ней осуществляется доступ из нескольких потоков, и доступ никак не синхронизирован.
Это стандартная проблема разделения ресурсов между и не исключена ситуация, что threadCount никогда не достигнет 0.
Собственно чтобы я хотел попросить: прокомментировать код, указать на проблемные места и предложить пример более удачной реализации. Хочу понять где слабые места и что надо подтянуть в плане знаний и навыков. Заранее всем благодарен!
0
Вложения
Тип файла: rar Program.rar (1.2 Кб, 36 просмотров)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.11.2016, 13:02
Здравствуйте! Я подобрал для вас темы с ответами на вопрос .NET 4.x Прошу консультации экспертов (ООП, многопоточность) (C#):

Прошу мнения экспертов - PHP
Всем здрасте! 'Недавно начал изучать PHP' короче бла-бла-бла=) Прислали мне тест сгенерировать html табличку.Сделать функцию которая...

Прошу совета экспертов о смене провайдера интернет - Сети
Здравствуйте. Сейчас тормозящий оптоволоконный ДжиПон 70 Мбит (реально до 30), хочу сменить на 2Ком или Билайн, что посоветуете? Читал...

Прошу консультации в выборе! - Выбор ноутбука
Добрый день уважаемые форумчане! Нужна ваша квалифицированная помощь в выборе ноутбука. Сразу опишу принцип будущего использования, время...

Прошу консультации по iptables - Ubuntu Linux
Доброго всем времени суток! Установлена у меня ubuntu 10.04. Поставлен apache2 в качестве веб сервера и ещё иное серверное ПО. Вот...

Прошу консультации по поводу запросов - WordPress
Доброго времени, подскажите пожалуйста следующий момент, допустим у меня есть страничка на которой хочу отображать данные из базы данных. В...

Прошу Вашей профессиональной консультации - Программирование Android
Всем здравствуйте уважаемые. Помогите разобраться в логах. Не могу "вкурить" что хочет от меня android studio. Добавил в свой проект код...

45
freeba
Неадекват
1183 / 975 / 107
Регистрация: 02.04.2010
Сообщений: 2,257
Записей в блоге: 2
Завершенные тесты: 2
27.01.2017, 19:35 #46
Цитата Сообщение от movorpovor Посмотреть сообщение
Разве не нужно try/catch блок вынести в каждый поток отдельно?
Нет. Внутри рабочих потоков не может возникнуть исключения, соответственно отлов исключений там не нужен.
0
27.01.2017, 19:35
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.01.2017, 19:35
Привет! Вот еще темы с ответами:

Тестирование компонентов по даташиту. Прошу консультации - Электроника
Рассмотрим предлагаемые тесты в даташите на мосфет FR9024N (в качестве примера).

Прошу консультации с HP Pavilion dv6 3057er - Ремонт ноутбуков
Всем привет! Прошу консультации. Ноутбук HP Pavilion dv6 3057er. Windows 7 Домашняя базовая лицензия. Начались сильные подвисания....

Выбор библиотеки для работы с *.pdf прошу консультации - Java
Всем добрый день. Возникла потребность редактирования pdf джавой. Погуглив, увидел что библиотек для этих целей достаточно много в...

Помощь экспертов - C++
как можно автоматически создавать названия функции т.е. как можно сгенерировать название функции. Пример. имеется такая задача: что в...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
46
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru