The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]



"Ядро операционной системы стало узким местом при выполнении ..."
Версия для распечатки Пред. тема | След. тема
Форум Разговоры, обсуждение новостей
Исходное сообщение [ Отслеживать ]
Заметили полезную информацию ? Пожалуйста добавьте в FAQ на WIKI.
. "Ядро операционной системы стало узким местом при выполнении ..." +16 +/
Сообщение от anonym0use (?), 12-Фев-15, 05:54 
Провел свое собственное исследование. Взял за основу рабочий код!

#include <stdio.h>
int main(void)
{
    for (int i = 0; i < 3000000;i++) {
        putchar('0');
        fflush(stdout);
    }
    return 0;
}

Обнаружил, что 87% времени выполнения тратится на выполнение кода внутри ядра!
gcc49 -O2 -std=c99 -Wall test.c 
$ time ./a.out > /dev/null

real    0m1.173s
user    0m0.142s
sys     0m1.030s


Долго думал, решил убрать fflush и проверить еще раз -- НЕВЕРОЯТНО, но это позволило сократить задержку записи в ядре в 114 раз!!
$ time ./a.out > /dev/null 
real    0m0.019s
user    0m0.010s
sys     0m0.009s

Ответить | Правка | Наверх | Cообщить модератору

Оглавление
Ядро операционной системы стало узким местом при выполнении ..., opennews, 11-Фев-15, 22:16  [смотреть все]
Форумы | Темы | Пред. тема | След. тема



Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2024 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру