私は、Windows の優先度メカニズムを示す必要がある単純な「トレーニング」プロジェクトを持っています。
これは私のC++コードです:
#include <stdio.h>
#include <windows.h>
DWORD WINAPI Thread1(LPVOID);
int stop;
int sleep = 10000;
struct params {
int num;
bool* runflg;
};
long long counters[7] = {0,0,0,0,0,0,0};
int priority[7] = {THREAD_PRIORITY_IDLE, THREAD_PRIORITY_LOWEST, THREAD_PRIORITY_BELOW_NORMAL, THREAD_PRIORITY_NORMAL, THREAD_PRIORITY_ABOVE_NORMAL, THREAD_PRIORITY_HIGHEST, THREAD_PRIORITY_TIME_CRITICAL};
int main(int argc, char* argv[])
{
int thrds;
if (argc < 2) stop = 5;
else stop = atoi(argv[1]);
bool runFlag = true;
__int64 end_time;
LARGE_INTEGER end_time2;
HANDLE tm1 = CreateWaitableTimer(NULL, false, NULL);
end_time = -1 * stop * 10000000;
end_time2.LowPart = (DWORD) (end_time & 0xFFFFFFFF);
end_time2.HighPart = (LONG) (end_time >> 32);
SetWaitableTimer(tm1, &end_time2, 0,NULL, NULL, false);
//SetPriorityClass(GetCurrentProcess(), HIGH_PRIORITY_CLASS);
printf("process priority = %d \n", GetPriorityClass(GetCurrentProcess()));
SetProcessPriorityBoost(GetCurrentProcess(), true);
for (int i = 0; i < 7; i++) {
DWORD targetThreadId;
params* param = (params*)malloc(sizeof(params));
param->num = i;
param->runflg = &runFlag;
HANDLE t1 = CreateThread(NULL, 0, Thread1, param, 0, &targetThreadId);
SetThreadPriority(t1, priority[i]); //задание приоритета
PBOOL ptr1 = (PBOOL)malloc(sizeof(BOOL));
GetThreadPriorityBoost(t1, ptr1);
SetThreadPriorityBoost(t1, true); //запрет динамического изм. приоритета
CloseHandle(t1);
}
WaitForSingleObject(tm1,INFINITE);
runFlag = false;
CloseHandle(tm1);
printf("\n");
for (int i = 0; i < 7; i++) {
printf("%d - %ld\n",i, counters[i]);
}
return 0;
}
DWORD WINAPI Thread1(LPVOID prm)
{
params arg = *((params*)prm);
printf("thread # %d priority = %d \n", arg.num, GetThreadPriority(GetCurrentThread()));
while(1) {
counters[arg.num]++;
Sleep(0);
if(*(arg.runflg) == false)
break;
}
return 0;
}
コードでは、スレッドの優先順位が異なる 7 つのスレッドを作成します。すべてのスレッドには独自のカウンターがあります。プログラムは約 5 秒間実行され、その後、コンソールにスレッドの優先順位とその値が表示されます。1 年前に Win XP 32 で実行したとき、すべてが機能していました。優先度の低いスレッドほど、カウンター値が小さくなります。しかし、今では次のような奇妙な結果が得られました。
process priority = 32
thread # 0 priority = -15
thread # 1 priority = -2
thread # 2 priority = -1
thread # 3 priority = 0
thread # 4 priority = 1
thread # 5 priority = 2
thread # 6 priority = 15
0 - 5401405
1 - 5726804
2 - 6676367
3 - 8320768
4 - 3223481
5 - 3085247
6 - 3177885
優先度レベルが機能せず、カウンターがそのような奇妙な値 (昇順でソートされていない) を持っているのはなぜですか?