Форум программистов, компьютерный форум, киберфорум
The trick
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  

Пример многопоточности VB6

Запись от The trick размещена 23.12.2013 в 11:27
Показов 4923 Комментарии 0
Метки multithreading, vb

В примере показана возможность работы с потоками в VB6. Можно создать несколько потоков и менять их приоритет (TIME_CRITICAL ставить на свой страх и риск, я поставил пришлось кнопкой выключать комп). Работает только в скомпилированном варианте.
Форма
Visual Basic
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
Option Explicit
 
' Пример многопоточности VB6
' © Кривоус Анатолий Анатольевич (The trick), 2013
' Работает только в скомпилированном виде
 
Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long
Private Declare Function CreateThread Lib "kernel32" (lpThreadAttributes As Any, ByVal dwStackSize As Long, ByVal lpStartAddress As Long, lpParameter As Any, ByVal dwCreationFlags As Long, lpThreadId As Long) As Long
Private Declare Function SetThreadPriority Lib "kernel32" (ByVal hThread As Long, ByVal nPriority As Long) As Long
Private Declare Function GetThreadPriority Lib "kernel32" (ByVal hThread As Long) As Long
 
Private Const DC_PEN As Long = 19
Private Const INFINITE = &HFFFFFFFF
Private Const MAX = 255
 
Dim Threads As Collection
Dim Thread(MAX - 1) As Point
 
Private Sub cboPriority_Click()
    Dim i As Long
    i = cboThread.ListIndex
    If i >= 0 Then
        SetThreadPriority Threads(i + 1), cboPriority.ItemData(cboPriority.ListIndex)
    End If
End Sub
Private Sub cboThread_Click()
    Dim i As Long, p As Long
    i = cboThread.ListIndex
    If i >= 0 Then
        p = GetThreadPriority(Threads(i + 1))
        cboPriority.ListIndex = 0
        Do Until cboPriority.ItemData(cboPriority.ListIndex) = p
            cboPriority.ListIndex = cboPriority.ListIndex + 1
        Loop
    End If
End Sub
Private Sub cmdNewThread_Click()
    Dim hThread As Long, IDThread As Long, Pt As Point
    Randomize
    
    Pt.Pos.X = 100: Pt.Pos.Y = 100
    Pt.Spd1 = 0.000001: Pt.Spd2 = 0.00000001
    Pt.Color = RGB(Rnd * 255, Rnd * 255, Rnd * 255)
    Pt.Status = True
    
    Thread(Threads.Count) = Pt
    hThread = CreateThread(ByVal 0, 0, AddressOf MoveProc, Thread(Threads.Count), 0, IDThread)
    If hThread Then Threads.Add hThread Else MsgBox ("Неудалось создать поток"): Exit Sub
    SetThreadPriority hThread, 0
    cboThread.AddItem hThread
    cboThread.ListIndex = cboThread.ListCount - 1
End Sub
Private Sub Form_Load()
    Set Threads = New Collection
End Sub
Private Sub UnloadAll()
    Dim i As Variant, l As Long
    For Each i In Threads
        Thread(l).Status = False
        WaitForSingleObject CLng(i), INFINITE
        l = l + 1
    Next
End Sub
Private Sub Form_Unload(Cancel As Integer)
    UnloadAll
End Sub
Private Sub tmrTimer_Timer()
    Dim i As Long, Pt As Point
    picCanvas.Cls
    For i = 0 To Threads.Count - 1
        Pt = Thread(i)
        picCanvas.Line (Pt.Pos.X - 3, Pt.Pos.Y - 3)-Step(6, 6), Pt.Color, BF
        picCanvas.Print Threads(i + 1)
    Next
End Sub
Модуль
Visual Basic
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
Option Explicit
 
' Пример многопоточности VB6
' © Кривоус Анатолий Анатольевич (The trick), 2013
' Работает только в скомпилированном виде
 
Public Type Vector
    X As Double
    Y As Double
End Type
Public Type Point
    Pos As Vector
    Spd1 As Single
    Spd2 As Single
    Color As Long
    Status As Boolean
End Type
 
Public Play As Boolean
 
Private Const Pi2 = 6.28318530717959
 
Public Function MoveProc(Pt As Point) As Long
    Dim Ph1 As Single, Ph2 As Single, Scl As Single
    
    Do
        Ph1 = Ph1 + Pt.Spd1: Ph2 = Ph2 + Pt.Spd2
        If Ph1 > Pi2 Then Ph1 = Ph1 - Pi2
        If Ph2 > Pi2 Then Ph2 = Ph2 - Pi2
        Scl = Sin(Ph2)
        
        Pt.Pos.X = Cos(Ph1) * Scl * 100 + 100
        Pt.Pos.Y = Sin(Ph1) * Scl * 100 + 100
 
        ' Т.к. VB анализирует код, то в VB "думает" что
        ' никто не может обратится к локальной переменной этой процедуры извне
        ' в реальности к элементам массива Thread, модуля frmTest.
        ' Поэтому если не обрабатывать переменную Pt.Status, то VB "решит" (если стоит оптимизации кода)
        ' что значение ее всегда равно в теле цикла, и проверит значение до цикла
        ' Получится что цикл будет крутиться бесконечно.
        ' Чтобы такого не было вставляем вот эту строчку
        Pt.Status = Not Not Pt.Status
        
    Loop While Pt.Status
End Function
Миниатюры
Нажмите на изображение для увеличения
Название: Безымянный.png
Просмотров: 705
Размер:	89.5 Кб
ID:	1911  
Вложения
Тип файла: rar Многопоточность.rar (8.5 Кб, 419 просмотров)
Метки multithreading, vb
Размещено в Без категории
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Всего комментариев 0
Комментарии
 
Новые блоги и статьи
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений. . . .
21 мат мед. Планы на развитие модели здравоСохранения
anaschu 01.06.2026
AnyLogic: план развития симуляционной модели рабочего коллектива — динамический абсентеизм, реальные данные, три сценария сравнения Продолжаю серию постов о дискретно-событийной модели рабочего. . .
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
Модель здравосохранения 18. Чем здоровее работник, тем быстрее выгорает
anaschu 24.05.2026
Имитационная модель корпоративного здравоохранения: что показывает математика Сегодня в модели рабочего коллектива на AnyLogic появились три новые механики — выгорание через накопленную усталость,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru