почему он НЕ вернулся сразу же, когда случилось самое первое событие с первым сокетом, а позволил себе постоять в ядре и подождать ещё? Точнее так: допустим я ядро и пришёл какой-то пакет, относящийся к сокету процесса N. Как мне понять - бежать сразу будить процесс на тему одного сокета или подождать - вдруг в следующие микросекунды навалит ещё пакетов про другие сокеты ЭТОГО ЖЕ процесса и я смогу сходить 1 раз оптом? Ясно, что вопрос в ядре так не ставится, а возврат epoll_wait сразу с пачкой сокетов скорее следствие того, что ядро видит события от сетевухи тоже сразу оптом, оптом рассовывает по сокетам и потом уже смотриь какие бы процессы разбудить. Но это все равно лишь дебильные догадки, хотелось бы почитать про сабж детальнее.
А вот так... Когда захотел, тогда и вернулся... Шедулер ОС так работает, кроме этого, ты не можешь на самом деле даже знать, когда и в каком порядке случились эти два события
Обсуждают сегодня