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

rand() работает не так как нужно - C++

Восстановить пароль Регистрация
 
tiptop_crazy
0 / 0 / 0
Регистрация: 27.05.2012
Сообщений: 39
04.04.2013, 20:18     rand() работает не так как нужно #1
Запускается n потоковых функций, каждый из них приостанавливается во время своего выполнения, а в главное программе должен перезапускаться. Перед остановкой потока ему нужно задать произвольный приоритет( от idle до above_normal). Но получается, что всем потокам рандом даёт одно и то же число. Точнее он, наверное, не пересчитывается. Подскажите, пожайлуста, как исправить? (В коде напротив рандома комментарий стоит)
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
153
154
155
156
157
158
159
160
161
162
163
164
165
#include <stdio.h>
#include <iostream>
#include <time.h>
 
#include <windows.h>
using namespace std;
 
DWORD WINAPI work(LPVOID iNum);
CRITICAL_SECTION cs;
int count=0;
 
struct data
{
    float mass[9];
    float res;
    void copy(float a[])
    {
        for(int i=0;i<9;i++)
            mass[i]=a[i];
    }
};
 
data* ThreadData;
 
int main(  )
{   
   FILE *stream;  
   InitializeCriticalSection(&cs);
   if( (stream = fopen( "in.txt", "r" )) == NULL )
   {
      cout<<"Main file not found\n";
   }
   int count=0;
   fscanf(stream,"%d",&count);
   char dummy;
   fscanf(stream,"%c",&dummy);
 
   char** names;
   if(count!=0)
   {
        names=new char*[count];
        for(int i=0;i<count;i++)
        {           
            names[i]=new char[200];
            fgets( names[i], 200, stream  );            
            names[i][strlen(names[i])-1]=0;     
        }           
   }
   else
   {
        cout<<"0 files\n";
        system("PAUSE");
        return 2;
   }   
   fclose( stream );
 
   ThreadData=new data[count];
 
   EnterCriticalSection(&cs);
   for(int i=0;i<count;i++)
   {
        stream=fopen( names[i],"r");
        if(stream==NULL)
        {
            cout<<"File "<< names[i]<<" not found\n";
            system("PAUSE");
            return 1;
        }
        float mass[9];
        for (int j = 0; j < 9; j++)
        {
            fscanf(stream, "%f", &mass[j]);      
        }
        ThreadData[i].copy(mass);
        fclose(stream);
    }
   LeaveCriticalSection(&cs);
    for(int i=0;i<count;++i)            
        delete [] names[i]; 
    delete[] names;
    HANDLE*     hThread=new HANDLE[count];
    DWORD*  IDThread=new DWORD[count];
    for(int i=0;i<count;i++)
        hThread[i] = CreateThread(NULL, 0, work, (void*)i, 0, &IDThread[i]);
    Sleep(500);
    
    for(int i=0;i<count;i++)
    {
        
        for(int level=0;level<5;level++)
        {
            if(GetThreadPriority(hThread[i])==THREAD_PRIORITY_IDLE&&level==0)
                ResumeThread(hThread[i]);
            else if(GetThreadPriority(hThread[i])==THREAD_PRIORITY_LOWEST&&level==1)
                ResumeThread(hThread[i]);
            else if(GetThreadPriority(hThread[i])==THREAD_PRIORITY_BELOW_NORMAL&&level==2)
                ResumeThread(hThread[i]);
            else if(GetThreadPriority(hThread[i])==THREAD_PRIORITY_NORMAL&&level==3)
                ResumeThread(hThread[i]);
            else if(GetThreadPriority(hThread[i])==THREAD_PRIORITY_ABOVE_NORMAL&&level==3)
                ResumeThread(hThread[i]);
        }
    }
    if (WaitForMultipleObjects(count, hThread, TRUE, INFINITE) == WAIT_FAILED)
    {
        cout << "Wait for multiple objects failed." << endl;
        cout << "Input any char to exit." << endl;
        system("PAUSE");        
    }
    
    for(int i=0;i<count;i++)
        CloseHandle(hThread[i]);
    
    DeleteCriticalSection(&cs);
    
    for(int i=0;i<count;i++)
        cout<<"File "<<(i+1)<<" result: "<<ThreadData[i].res<<endl;
    delete [] ThreadData;
 
   system("PAUSE");
   return 0;
}
 
DWORD WINAPI work(LPVOID arg)
{
    EnterCriticalSection (&cs);
    count++;
    char IncBuffer[3];  
    itoa(count,IncBuffer,10);       
    char IncOut[10]="title ";
    strcat(IncOut,IncBuffer);
    system(IncOut); 
    LeaveCriticalSection(&cs);
    HANDLE hThread = GetCurrentThread();
    srand(time(0));                                                                 
    int choise=rand()%5;                                         //тут рандом
    switch(choise)
    {
    case 0: SetThreadPriority(hThread, THREAD_PRIORITY_IDLE);cout<<choise<<endl;break;
    case 1: SetThreadPriority(hThread, THREAD_PRIORITY_LOWEST);cout<<choise<<endl;break;
    case 2: SetThreadPriority(hThread, THREAD_PRIORITY_BELOW_NORMAL);cout<<choise<<endl;break;
    case 3: SetThreadPriority(hThread, THREAD_PRIORITY_NORMAL);cout<<choise<<endl;break;
    case 4: SetThreadPriority(hThread, THREAD_PRIORITY_ABOVE_NORMAL);cout<<choise<<endl;break;
    }   
    
    int num = (int)(arg);
    SuspendThread(hThread);   
    EnterCriticalSection (&cs); 
    ThreadData[num].res = ThreadData[num].mass[0] * ThreadData[num].mass[4] * ThreadData[num].mass[8] +
        ThreadData[num].mass[2] * ThreadData[num].mass[3] * ThreadData[num].mass[7] + 
        ThreadData[num].mass[1] * ThreadData[num].mass[5] * ThreadData[num].mass[6] -
        ThreadData[num].mass[2] * ThreadData[num].mass[4] * ThreadData[num].mass[6] -
        ThreadData[num].mass[1] * ThreadData[num].mass[3] * ThreadData[num].mass[8] -
        ThreadData[num].mass[0] * ThreadData[num].mass[5] * ThreadData[num].mass[7];
    count--;
    char DecBuffer[3];  
    itoa(count,DecBuffer,10);       
    char DecOut[10]="title ";
    strcat(DecOut,DecBuffer);
    system(DecOut);
    LeaveCriticalSection(&cs);
 
    return 0;
}
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
buy
4 / 4 / 0
Регистрация: 12.03.2013
Сообщений: 24
04.04.2013, 20:37     rand() работает не так как нужно #2
а дебажить пробовал?
tiptop_crazy
0 / 0 / 0
Регистрация: 27.05.2012
Сообщений: 39
04.04.2013, 22:00  [ТС]     rand() работает не так как нужно #3
Да. Но, во первых, я не умею дебажить когда потоки, ибо оно не делает шаг вперёд там где должны работать параллельно несколько потоков. Но я пробовал выводить всё что оно рандомит и всегда это было одно и то же число.
Кстати volatine или как оно там, я тоже уже пробовал использовать..
ViktorKozlov
133 / 125 / 2
Регистрация: 13.12.2012
Сообщений: 293
04.04.2013, 22:09     rand() работает не так как нужно #4
Чтобы не выводились одни и те же числа, нужно засеять этот rand
C++
1
srand(unsigned(time(NULL)))
А отлаживать можно логированием
tiptop_crazy
0 / 0 / 0
Регистрация: 27.05.2012
Сообщений: 39
04.04.2013, 22:33  [ТС]     rand() работает не так как нужно #5
Цитата Сообщение от ViktorKozlov Посмотреть сообщение
Чтобы не выводились одни и те же числа, нужно засеять этот rand
C++
1
srand(unsigned(time(NULL)))
А отлаживать можно логированием
Я знаю про srand(unsigned(time(NULL))), оно есть в программе. Если запускать не в одновременно работающих потоках, то оно конечно действует. Но в программе это есть, но всё равно числа одинаковые. Оно скорее всего высчиталось при первом использовании функции потока и дальше просто не пересчитывается..
ViktorKozlov
133 / 125 / 2
Регистрация: 13.12.2012
Сообщений: 293
04.04.2013, 23:04     rand() работает не так как нужно #6
Наверное, для каждого потока она засеивает отдельно.. попробуйте использовать не time(0), а счетчик какой-нибудь, который после каждого srand'а увеличивается. Может быть, они просто запускаются в одно и то же время, поэтому и засеиваются одинаково
Yandex
Объявления
04.04.2013, 23:04     rand() работает не так как нужно
Ответ Создать тему
Опции темы

Текущее время: 14:55. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru