- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 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
// Этот код отрабатывает при старте программы.
// Он запускает некоторое количество потоков
for (int ThrNum=0; ThrNum<=(MAX_THREADS-1); ThrNum++){ // threads loop
DWORD ThreadID;
hEventsArrayRdy[ThrNum] = CreateEvent(NULL,TRUE,FALSE,NULL);
hEventsArrayRqst[ThrNum] = CreateEvent(NULL,TRUE,FALSE,NULL);
hThreadArray[ThrNum] = CreateThread(NULL,0,RuskThrdFunc1,0,0,&ThreadID);
}
// Вот эта радость основная функция, которую движок запускает на n потоков. Скажем, на 16.
// Тут поток ожидает команды на выполнение полезной нагрузки
// И здесь же ставит флаг о том, что полезная нагрузка выполнена.
// Как видно, он ищет еще не занятую область экрана после того, как отработал предыдущую.
DWORD WINAPI RuskThrdFunc1( LPVOID lpParam ){ // standart function for one thread
int THRD_num,RunNew,ScrAr;
AvoidWarn=lpParam; // warning avoid
// > detect thread num
EnterCriticalSection(&RuskMTSec); // enter to critical section
ThreadNumb++;THRD_num=ThreadNumb; // for thread num detect
LeaveCriticalSection(&RuskMTSec); // leave critical section
// < detect thread num
// > main thread wait time
more:;
DWORD dwWaitResult = WaitForSingleObject(hEventsArrayRqst[THRD_num],INFINITE); // wait for request
if (dwWaitResult==WAIT_OBJECT_0){ // request is correct, so start it realization
ResetEvent(hEventsArrayRqst[THRD_num]); // no more wait for request
// < main thread wait time
//
//
// >> main calculation
goto startcalc; // jump to entry point
calcmore:;
// > calculate calls
if (GlThr_RequestId==THREQ_3dbasil){rusk.B3D_putThrds(SCRARMT,RunNew);} // __ put all =3d-basil= direct
if (GlThr_RequestId==THREQ_gingerbr){rusk.GBputThrds(SCRARMT,RunNew);} // __ put all =gb system= pics
if (GlThr_RequestId==THREQ_user01){rusk.User01Mult(SCRARMT,RunNew);} // __ request for user 01 private multithr func
// < calculate calls
// > search for uncalculated screen area
startcalc:;
EnterCriticalSection(&RuskMTSec); // enter to critical section
RunNew=-1; // no screen part for calculate by default
for (ScrAr=0; ScrAr<SCRARMT; ScrAr++){ // loop all screen parts
if (ScrAreaReq[ScrAr]==0){ScrAreaReq[ScrAr]=1;RunNew=ScrAr;break;} // find next free area for calculating it
}
LeaveCriticalSection(&RuskMTSec); // leave critical section
if (RunNew>=0){goto calcmore;} // screen area for calculating is found
// < search for uncalculated screen area
// << main calculation
//
//
// > put rdy signal and go to wait time
SetEvent(hEventsArrayRdy[THRD_num]); // set flag, that request is done
}
goto more; // go to wait for next request
// < put rdy signal and go to wait time
return 0;
}
// А вот так движок посылает сигнал всем запущенным потокам, что пора просыпаться и работать.
// Здесь же движок ожидает завершения работы всех потоков.
GlThr_RequestId=THREQ_3dbasil; // request id for threads
for (int ScrAr=0; ScrAr<SCRARMT; ScrAr++){ScrAreaReq[ScrAr]=0;} // ini screen areas flags
for(int i=0; i<=(MAX_THREADS-1); i++){SetEvent(hEventsArrayRqst[i]);} // request all theads to calculate
WaitForMultipleObjects(MAX_THREADS, hEventsArrayRdy, TRUE, INFINITE); // wait for all threads
for(int i=0; i<=(MAX_THREADS-1); i++){ResetEvent(hEventsArrayRdy[i]);} // wait all threads no more
guest 07.10.2016 01:24 # +1
Стиль кодирования -"феерия"
kurwa 07.10.2016 02:21 # +6
guest 07.10.2016 02:41 # 0
guest 07.10.2016 14:07 # −3
И да, на сходочке он еще куски показывал, там даже отступ в одном месте был. Или в двух. На проект.
guest 07.10.2016 06:41 # −7
guest 07.10.2016 07:08 # 0
Так что пошел нахуй обоссаная защеканская шлюха Мухосранска.
guest 07.10.2016 07:23 # −2
guest 07.10.2016 09:13 # −2
guest 07.10.2016 07:10 # +1
gost 07.10.2016 23:34 # 0
barop 08.10.2016 03:57 # 0
guest 07.10.2016 08:44 # −1
guest 07.10.2016 14:17 # −1
voodoodal16 07.10.2016 14:39 # −64
guest 07.10.2016 14:40 # +1
voodoodal16 07.10.2016 14:40 # −64
guest 07.10.2016 18:08 # −1
voodoodal16 07.10.2016 20:25 # −64
Не забыл, не удалил, не Страйко затёр - наебнулись вместе с диском. Неслыханно.
guest 07.10.2016 20:35 # 0
Пойду забекаплю свои сорцы и ботов.
Кстати, я своим дал одинаковые пароли, и однотипные имена. Восстановить будет легче
guest 07.10.2016 20:45 # 0
guest 07.10.2016 20:57 # 0
но пароль от моих первых ботов ты отгадал правильно
guest 07.10.2016 22:24 # 0
guest 07.10.2016 22:26 # 0
Вопрос: зачем? Ты стройко?
CTEPTOP 08.10.2016 01:01 # −64
guest 08.10.2016 01:39 # +2
barop 10.10.2016 04:00 # +1
зацени
guest 07.10.2016 20:36 # −1
guest 07.10.2016 20:46 # +1
voodoodal16 07.10.2016 14:33 # −64
ThreadNumb++;THRD_num=ThreadNumb; // for thread num detect
LeaveCriticalSection(&RuskMTSec);
- InterlockedIncrement? Не, не слышал.
Povelitel 07.10.2016 20:10 # 0
guest 07.10.2016 23:42 # 0
How about
```
std::atomic<int> ThreadNumb;
//...
ThreadNumb++;
```
?
CTEPTOP 08.10.2016 00:59 # −64
>>std::atomic<int> ThreadNumb;
А хуй его, как у вас в сишке.
guest 08.10.2016 02:09 # 0
guest 08.10.2016 03:01 # 0
guest 07.10.2016 20:59 # 0
guest 07.10.2016 21:00 # 0
guest 07.10.2016 23:27 # 0
gost 07.10.2016 23:34 # −1
Сжечь нахуй.
guest 07.10.2016 23:55 # 0
"A thread in an executable that calls the C run-time library (CRT) should use the _beginthreadex and _endthreadex functions for thread management rather than CreateThread and ExitThread; this requires the use of the multithreaded version of the CRT. If a thread created using CreateThread calls the CRT, the CRT may terminate the process in low-memory conditions."
Это потому, что программист не может нормально вычислить размер стека под тред, в котором вызывается CRT, а _beginthreadex может? Или в чем дело?
barop 08.10.2016 00:04 # 0
http://www.viva64.com/en/w/V513/print/
barop 08.10.2016 00:01 # 0
Win32APIшный кол же для читых сей, кода с CRT не линкуешься