делать не стоит, но все же, такое задание лабы.
Мне нужно ограничить кол-во памяти, которое может использовать приложение и время, которое приложение(поток, дочерний процесс или Task) может выполняться. Дословно задача стоит так: "Передбачити можливість обмеження виконання програми за часом (30 хвилин) та використання пам’яті (512 Мб)"
Я вижу 2 варианта, но оба мне не очень нравятся.
1. Запускать анализ доски в Task<T> и тогда можно будет прокинуть cancellationToken это ограничит время. И тут возникает вопрос, а как ограничить память для Task'a. Есть вариант дергать метод GC.GetAllocatedBytesForCurrentThread, но это выглядит как-то костыльненько.
2. Создавать новый дочерний процесс, что выглядит не очень хорошо, т.к. процессы довольно тяжелые и не удобные. И тогда нужно будет городить, что-то для трека времени. Зато, можно дернув WinApi ограничить память.
Может, есть какой-то более лаконичный вариант, который позволит избежать оверхеда?)
це ця програма для генерації шахів на досці?
ясно, универ начался))0
А с ним и невменяемое кол-во конченых задач, которые ничего общего с реальностью не имеют. Вот схерали мне в реальной жизни ограничивать память?!
Можно в докер засунуть и на его уровне ограничить
а не слишком ли оверхедно для лабы с универа))
Как вариант, но тогда нужно будет еще сделать, чтобы докер запускался 20 раз
Я думаю алгоритм має виконатися менше чи за пів часа
Ну для меня нет, я это уже во сне делаю на автомате)
а раскажешь как установить докер не на диск C ?)
Нет, вообще может и дольше. Там даже теоретически овермного вариантов возможно
Не, таким никогда не занимался, у меня С на 1 ТБ)
повезло повезло)
Можно извернуться, скопировав все и подсунув симлинк, только тсс
На самом деле достаточно регулярно делать docker prune и выполнять команды с --rm, они сами за собой подчищают весь мусор
Ну вообще никто не запрещает взять такую штуку например https://www.amazon.com/Intel-660p-1-0TB-80mm-978350/dp/B07GCL6BR4 Понятное дело что это самый дешман на рынке, но оно все равно быстро
У меня уже почти час пытается решить такую доску
Мне кажется кстати для таких задач можно было бы параллельность заюзать, если не перерисовывать постоянно Большое кол-во расчётов
Оно не перерисовывается. Это начальное состояние, а потом будет еще и конечное
Ну значит подошло бы) в самый раз
Обсуждают сегодня