Форум программистов, компьютерный форум CyberForum.ru

Время работы потока - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Волны вокруг курсора http://www.cyberforum.ru/cpp-beginners/thread135331.html
Здравствуйте, мне нужно написать программу такого рода: Кликая по экрану, вокруг курсора должны появляться волны, подобно тому, как при броске камня в воду. Т.е. при каждом щелчке мыши, вокруг курсора должны появляться круги, постепенно расширяющиеся. Был бы рад, если б вы помогли, хотя бы частично в написании программы. Или же если видели готовые подобные программы, поделись пожалуйста ссылочкой...
C++ Массив с++ (удаление простых чисел) Нужно написать програмку : Задан массив Z(k) целых чисел. Записать все элементы массива Z в массив Y, записав числа в обратном порядке (например, 1234 запишется как 4321). Удалить из массива Z все простые числа. Сравнить максимальные и минимальные элементы массивов. :) В крайнем случае хотябы помогите с простыми числами...Заранее спасибо. http://www.cyberforum.ru/cpp-beginners/thread135326.html
Вычислить количество цифр в заданной строке C++
Добрий день товарищи!!! Помогите написать програму... Написать программу, которая вычисляет количество цифр в заданной строке.
C++ с++ цикли
Помогите решить зачаски буду очень благодарен я уверен есть ище добрие люди( Задача 3. Найти первых 10 натуральных чисел, нацело делятся на 19 и находятся в интервале, левая граница которого 100. Завдання 4. Дано натуральные m, n. Получить сумму m последних цифр числа n.
C++ Одномерные масивы http://www.cyberforum.ru/cpp-beginners/thread135297.html
Приветик у меня проблемка помогите плиз решить прошку В одномерном массиве с четным количеством элементов (2N) находятся координаты N точек плоскости. Они располагаются в следующем порядке: x1, у1, х2, у2, x3, y3 и т.д. Определить кольцо с центром в начале координат, которое содержит все точки.
C++ Одномерные масивы приветик помогите плиз решить прогу Разделить массив на две части, поместив в первую элементы, большие среднего арифметического их суммы, а во вторую — меньшие (части не сортировать). подробнее

Показать сообщение отдельно
st_kastiel
0 / 0 / 0
Регистрация: 16.04.2010
Сообщений: 14
25.05.2010, 16:22     Время работы потока
Вот есть такой код. Время работы потока выводит 0! Вроде все норм, а 0 выводит. Помогите люди умные)

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
// OC_3.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <stdio.h>
#include <windows.h>
#include <iostream>
#include <conio.h>
using namespace std;
 
int h,m,s,h1,m1,s1, sum1,sum2,rez;
const int NANOSECOND_BLOCKS_IN_MILLISECOND = 10000.0;
 
 
__int64 FileTimeToQuadWord(PFILETIME pFileTime)
{
const int bits = 32;
// квадрослово формируется из двух 32-битных чисел
return(Int64ShllMod32(pFileTime->dwHighDateTime // сдвиг верхних 32 битов
                                                , bits // сдвиг влево на 32 бита
                                                        ) // результат - верхняя часть квадрослова
                                                            | pFileTime->dwLowDateTime // нижняя часть квадрослова
                                                                                        );
}                           
 
DWORD WINAPI fpot(LPVOID iNum)
{
    rez=sum2-sum1;
    return rez;
}
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(LC_ALL, "Russian");
    
    // выделить непосредственно память
    FILETIME threadStart; // начало работы потока
    FILETIME threadEnd; // окончание работы потока
    FILETIME dummy; // неиспользуемое значение
 
    DWORD idThread, idThread2;
    HANDLE hThread1, hThread2;
 
    
    
    cout<<"Введите первое значение времени ЧЧ:ММ:СС\n";
point:
    cin>>h>>m>>s;
        if ( ((m||s)>60) || ((m||s)<0) || (h>24) || (h<0) )
        {
            cout<<"Некорректное значение времени, введите корректно\n";
            goto point;
        }
 
    sum1=(s+(h*3600)+(m*60));
 
    cout<<"Первое значение времени в секундах:"<<sum1<<"\n\n";
 
    cout<<"Введите второе значение времени ЧЧ:ММ:СС\n";
 
point2:
 
    cin>>h1>>m1>>s1;
 
        if ( (((m1||s1)>60) || ((m1||s1)<0)) || ((h1>24) || (h1<0)) )
        {
            cout<<"Некорректное значение времени, введите корректно\n";
            goto point2;
        }
 
    sum2 = (s1+(h1*3600)+(m1*60));
 
    cout<<"Второе значение времени в секундах: "<<sum2<<"\n\n";
 
    
    hThread1 = CreateThread (NULL, 0, fpot, 0, CREATE_SUSPENDED, &idThread);
    hThread2 = CreateThread (NULL, 0, fpot, 0, CREATE_SUSPENDED, &idThread2);     
 
    if( (hThread1||hThread2) == NULL)
        return GetLastError();
    else cout<<"Потоки созданы\n";
 
    // созданному потоку устанавливается приоритет HIGHEST
    SetThreadPriority(hThread1  // дескриптор первого потока
                        , THREAD_PRIORITY_NORMAL ); // уровень приоритета
    // 2му созданному потоку устанавливается приоритет LOWEST
    SetThreadPriority(hThread2  // дескриптор первого потока
                        , THREAD_PRIORITY_LOWEST  // уровень приоритета
                                                    );
    // выполнение потока в данном случае вызовом функции возобновления
    ResumeThread(hThread1);
    ResumeThread(hThread2);
 
    cout<<"Тaблицa 1 Стaндaртные знaчения приoритетa пoтoкa числoвoе знaчение\n\n";
                cout<<" THREAD_PRIORITY_TT.ME_CRITT.CAL 15\n";
                cout<<" THREAD_PRIORITY_HIGHEST 2\n";
                cout<<" THREAD_PRIORITY_ABOVE_NORMAL 1\n";
                cout<<" THREAD_PRIORITY_NORMAL 0\n";
                cout<<" THREAD_PRIORITY_BELOW_NORMAL -1\n";
                cout<<" THREAD_PRIORITY_LOWEST -2\n";
                cout<<" THREAD_PRIORITY_IDLE -15\n\n";
 
    cout<<"Приоритет первого потока равен: "<<GetThreadPriority(hThread1)<<"\n\n";
    cout<<"Приоритет второго потока равен: "<<GetThreadPriority(hThread2)<<"\n\n";
 
    
    
    GetThreadTimes(hThread1,
                 &threadStart,
                 &threadEnd,
                 &dummy,
                 &dummy
                            );  
    
 
        
    __int64 qwStartTime, qwFinishTime, qwTotalTimeElapsed;
    qwStartTime = FileTimeToQuadWord(&threadStart);
    qwFinishTime = FileTimeToQuadWord(&threadEnd);
    qwTotalTimeElapsed = qwFinishTime - qwStartTime;
    // вывод значения времени работы потока в миллисекундах
     
    
        WaitForSingleObject(hThread1, INFINITE);
 
 
    
    cout<< " Первый поток выполнился за "<< qwTotalTimeElapsed/NANOSECOND_BLOCKS_IN_MILLISECOND << " миллисекунд";
    
    GetThreadTimes(hThread2,
                 &threadStart,
                 &threadEnd,
                 &dummy,
                 &dummy
                        );  
    
    qwStartTime = FileTimeToQuadWord(&threadStart);
    qwFinishTime = FileTimeToQuadWord(&threadEnd);
    qwTotalTimeElapsed = qwFinishTime - qwStartTime;
    // вывод значения времени работы потока в миллисекундах
 
    WaitForSingleObject(hThread2, INFINITE);
 
    cout<< "\n Второй поток выполнился за "<< qwTotalTimeElapsed/NANOSECOND_BLOCKS_IN_MILLISECOND  << " миллисекунд";
    
    cout<<"\nРазница между первым и вторым значениями времени в секундах:"<< rez<<"\n";
 
    
    
    getch();
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 19:30. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru