Жанры книг
Мы в соц.сетях
ParaKnig📚 » Компьютеры и Интернет » Интернет » QNX/UNIX: Анатомия параллелизма - Цилюрик Олег Иванович
<< На главную

QNX/UNIX: Анатомия параллелизма - Цилюрик Олег Иванович

Читать онлайн QNX/UNIX: Анатомия параллелизма - Цилюрик Олег Иванович

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать
1 ... 21 22 23 24 25 26 27 28 29 ... 106
Перейти на страницу:

 time_t tv_sec;  // значение секунд

 long   tv_nsec; // значение наносекунд

}

При успешном выполнении функция sched_rr_get_interval()возвращает 0, в противном случае -1.

Примечание

Две другие функции, часто удобные для работы со структурой timespec:

#include &lt;time.h&gt;

void nsec2timespec(struct timespec *timespec_p, _uint64 nsec);

— это преобразование интервала, выраженного в наносекундах (nsec), в структуру timespec(«выходной» параметр вызова timespec_p);

#include &lt;time.h&gt;

_uint64 timespec2nsec(const struct timespec* ts);

— это преобразование структуры timespec в значение, выраженное в наносекундах (это функция из native API QNX).

3. Спорадическая диспетчеризация — это гораздо более развитая форма «вытесняющей многозадачности», численные характеристики которой (время кванта, численные значения приоритетов и др.) могут детально параметризироваться и даже динамически изменяться по ходу выполнения. Подробнее спорадическая диспетчеризация рассмотрена далее.

Часто задают вопрос: «А как много потоков целесообразно делать? Не сколько снижается эффективность многопоточной программы за счет диспетчеризации потоков?» С другой стороны, в литературе часто встречаются (достаточно голословные, на качественном уровне) утверждения, что многопоточная программа будет заметно уступать в фиктивности своему последовательному (в одном потоке) эквиваленту. Проверим это на реальной задаче:

Множественные потоки в едином приложении

#include &lt;stdlib.h&gt;

#include &lt;stdio.h&gt;

#include &lt;iostream.h&gt;

#include &lt;unistd.h&gt;

#include &lt;limits.h&gt;

#include &lt;pthread.h&gt;

#include &lt;inttypes.h&gt;

#include &lt;sys/neutrino.h&gt;

#include &lt;sys/syspage.h&gt;

#include &lt;errno.h&gt;

#include &lt;math.h&gt;

// преобразование процессорных циклов в миллисекунды:

static double cycle2milisec(uint64_t ccl) {

 const static double s2m = 1.E+3;

 // это скорость процессора

 const static uint64_t

 cps = SYSPAGE_ENTRY(qtime)-&gt;cycles_per_sec;

 return (double)ccl * s2m / (double)cps;

}

static int nsingl = 1;

// рабочая функция, которая имитирует вычисления:

void workproc(int how) {

 const int msingl = 30000;

 for (int j = 0; j &lt; how; j++)

  for (uint64_t i=0; i &lt; msingl * nsingl; i++)

   i = (i + 1) - 1;

}

static pthread_barrier_t bstart, bfinish;

struct interv { uint64_t s, f; };

interv *trtime;

void* threadfunc(void* data) {

 // все потоки после создания должны &quot;застрять&quot; на входном

 // барьере, чтобы потом одновременно &quot;сорваться&quot; в исполнение

 pthread_barrier_wait(&amp;bstart);

 int id = pthread_self() - 2;

 trtime[id].s = ClockCycles();

 workproc((int)data);

 trtime[id].f = ClockCycles();

 pthread_barrier_wait(&amp;bfinish);

 return NULL;

}

int main(int argc, char *argv[]) {

 // здесь только обработка многочисленных ключей...

 int opt, val, nthr = 1, nall = SHRT_MAX;

 while ((opt = getopt(argc, argv, &quot;t:n:p:a:&quot;)) != -1) {

  switch(opt) {

  case 't':

   if (sscanf(optarg, &quot;%i&quot;, &amp;val) != 1)

    perror(&quot;parse command line failed&quot;), exit(EXIT_FAILURE);

   if (val &gt; 0 &amp;&amp; val &lt;= SHRT_MAX) nthr = val;

   break;

  case 'p':

   if (sscanf(optarg, &quot;%i&quot;, &amp;val) != 1)

    perror(&quot;parse command line failed&quot;), exit(EXIT_FAILURE);

   if (val != getprio(0))

    if (setprio(0, val) == -1)

     perror(&quot;priority isn't a valid&quot;), exit(EXIT_FAILURE);

   break;

  case 'n':

   if (sscanf(optarg, &quot;%i&quot;, &amp;val) != 1)

    perror(&quot;parse command line failed&quot;), exit(EXIT_FAILURE);

   if (val &gt; 0) nsingl *= val;

   break;

  case 'a':

   if (sscanf(optarg, &quot;%i&quot;, &amp;val) != 1)

    perror(&quot;parse command line failed&quot;), exit(EXIT_FAILURE);

1 ... 21 22 23 24 25 26 27 28 29 ... 106
Перейти на страницу:
На этой странице вы можете бесплатно читать книгу QNX/UNIX: Анатомия параллелизма - Цилюрик Олег Иванович бесплатно.
Комментарии
Открыть боковую панель
Комментарии
Лариса
Лариса 11.03.2026 - 20:17
Странно,здесь имя девочки Аграфена,а на других сайтах я прослушала три книги этого цикла с именем Дарвина.Зачем менять имя и путать читателей? Опечатка- не Дарвина,  а  Дарина.
Григорий
Григорий 09.04.2025 - 22:24
Лучшая книга всех времен
Женя
Женя 02.04.2025 - 16:08
Любимая книга