С помощью алгоритма банкира вы знаете общее количество доступных ресурсов и максимальное количество ресурсов, которое может запросить каждый процесс. Будучи консервативным, вы, в конце концов, банкир, вы полагаете, что любой процесс потребует своих максимальных ресурсов до завершения.
Когда запрашиваются ресурсы, вы сначала смотрите, достаточно ли осталось ресурсов, чтобы по крайней мере один процесс мог получить максимум. Если ресурсов не останется, вы не сможете удовлетворить запрос, поскольку перейдете в небезопасное состояние.
Теперь предположим, что все процессы, которые вы определили, могут получить свой максимум и завершить, сделали это и высвободили ресурсы, на которых они держались. Это позволит большему количеству процессов получить максимальный запрос и завершить его, высвободив больше ресурсов.
Повторяйте до тех пор, пока все процессы не будут завершены (в этом случае запрос разрешен для распределения) или пока не появятся некоторые процессы, которые не могут получить свой максимум, даже после того, как все процессы, которые могут завершить, освободили свои ресурсы.
На практике (и в тех случаях, когда экзаменационные задачи выполнялись вручную) обычно не требуется более пары проходов через список процессов, чтобы определить, находитесь ли вы в безопасном или небезопасном состоянии.