VB无所不能之七:VB的多线程(1)

简介:
题外话:
 
最近,写了几篇《VB无所不能》系列,本系列文章的创作初衷就是要去颠覆众多程序员对于“非面向对象”语言“VB”的成见!
 
当然,我也早有预期,此言一出必然招致不明真相的群众的“围攻”,然而,我还是要继续写下去,事实胜于雄辩,在这里我也想和广大网友说一声,如果要质疑我文章中的某些观点,欢迎拿出真凭实据与我辩论,切莫采取 “五毛党”式的语言 横加棒杀
 
再次声明关于“无所不能”:
 
本文系列为《VB无所不能》,并不是真的像孙悟空72变似的“无所不能”,想变一个蚊子变个蚊子,想变个大象变个大象,吃喝拉撒睡全用VB给你解决了那是不可能的,关于“VB是否无所不能”这个话题就不用再跟我争论了,任何语言都不能“无所不能”,这里的“无所不能”是一个“状语”,而不是“定语”,OK?
 
好,我们继续,最近有网友强烈要求我写一篇关于VB多线程的文章,我在博客的留言中大呼“头疼”!!
 
是啊,VB确实处理多线程是一个头疼的事情,比VB处理图像处理,钩子程序,和指针要头疼很多。头疼之处无非有如下几点:
 
1、VB本身没有多线程的处理机制
2、VB的大部分控件都不是线程安全的
3、动不动就莫名其妙的因为严重错误而程序崩溃
 
但,还是为了满足网友要求,我还是硬着头皮写一篇,如有不对之处,还请大家见笑了!!
 
一、首先我们来认识一下Windows的kernel32给我们提供的线程函数
 
CreateThread
 
说明:
微软在Windows API中提供了建立新的线程的函数CreateThread
 
概述:
当使用CreateProcess调用时,系统将创建一个进程和一个主线程。CreateThread将在主线程的基础上创建一个新线程,大致做如下步骤:
1.在内核对象中分配一个线程标识/句柄,可供管理,由CreateThread返回
2.把线程退出码置为STILL_ACTIVE,把线程挂起计数置1
3.分配context结构
4.分配两页的物理存储以准备栈,保护页设置为PAGE_READWRITE,第2页设为PAGE_GUARD
5.lpStartAddr和lpvThread值被放在栈顶,使它们成为传送给StartOfThread的参数
6.把context结构的栈指针指向栈顶(第5步)指令指针指向startOfThread函数
 
VB函数声明:
Declare Function CreateThread Lib "kernel32" (_
lpThreadAttributes As Any, _
ByVal dwStackSize As Long, _
ByVal lpStartAddress As Long, _
ByVal lpParameter As Long, _
ByVal dwCreationFlags As Long, _
lpThreadId As Long) As Long
 
参数说明:
lpThreadAttributes:
指向SECURITY_ATTRIBUTES型态的结构的指针。在Windows 98中忽略该参数。在Windows NT中,它被设为NULL,表示使用缺省值。
dwStackSize:线程堆栈大小,一般=0,在任何情况下,Windows根据需要动态延长堆栈的大小。
lpStartAddress:指向线程函数的指针,形式:@函数名,函数名称没有限制,但是必须以下列形式声明:DWORD WINAPI ThreadProc (LPVOID pParam) ,格式不正确将无法调用成功。 
lpParameter:向线程函数传递的参数,是一个指向结构的指针,不需传递参数时,为NULL。 
dwCreationFlags:线程标志,可取值如下 
CREATE_SUSPENDED: 创建一个挂起的线程 
0 :创建后立即激活。 
lpThreadId:保存新线程的id。
 
返回值:
  函数成功,返回线程句柄;函数失败返回false。
函数说明:
创建一个线程。
 
Sleep
 
VB声明:
Private Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long) 

调用:
Sleep 3000 '延时3秒执行
'这个是sleep,作用就是让两个线程绘图频率不一致,效果才明显。
Public Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)
 
好,今天我们认识了这两个函数,今天先写到这,明天我们给出例程,看看VB是如何利用这些函数完成多线程任务的吧。。






 本文转自 useway 51CTO博客,原文链接:http://blog.51cto.com/useway/301717,如需转载请自行联系原作者

相关文章
|
19天前
|
Java
实现Java多线程中的线程间通信
实现Java多线程中的线程间通信
|
17天前
|
设计模式 安全 Java
Java面试题:设计模式如单例模式、工厂模式、观察者模式等在多线程环境下线程安全问题,Java内存模型定义了线程如何与内存交互,包括原子性、可见性、有序性,并发框架提供了更高层次的并发任务处理能力
Java面试题:设计模式如单例模式、工厂模式、观察者模式等在多线程环境下线程安全问题,Java内存模型定义了线程如何与内存交互,包括原子性、可见性、有序性,并发框架提供了更高层次的并发任务处理能力
33 1
|
17天前
|
设计模式 存储 安全
Java面试题:设计一个线程安全的单例类并解释其内存占用情况?使用Java多线程工具类实现一个高效的线程池,并解释其背后的原理。结合观察者模式与Java并发框架,设计一个可扩展的事件处理系统
Java面试题:设计一个线程安全的单例类并解释其内存占用情况?使用Java多线程工具类实现一个高效的线程池,并解释其背后的原理。结合观察者模式与Java并发框架,设计一个可扩展的事件处理系统
26 1
|
19天前
|
Java
实现Java多线程中的线程间通信
实现Java多线程中的线程间通信
|
15天前
|
缓存 Linux 编译器
【Linux】多线程——线程概念|进程VS线程|线程控制(下)
【Linux】多线程——线程概念|进程VS线程|线程控制(下)
30 0
|
15天前
|
存储 Linux 调度
【Linux】多线程——线程概念|进程VS线程|线程控制(上)
【Linux】多线程——线程概念|进程VS线程|线程控制(上)
35 0
|
17天前
|
设计模式 并行计算 安全
Java面试题:如何使用设计模式优化多线程环境下的资源管理?Java内存模型与并发工具类的协同工作,描述ForkJoinPool的工作机制,并解释其在并行计算中的优势。如何根据任务特性调整线程池参数
Java面试题:如何使用设计模式优化多线程环境下的资源管理?Java内存模型与并发工具类的协同工作,描述ForkJoinPool的工作机制,并解释其在并行计算中的优势。如何根据任务特性调整线程池参数
20 0
|
17天前
|
设计模式 安全 NoSQL
Java面试题:结合单例模式与Java内存管理,设计一个线程安全的单例类?分析Java多线程工具类ExecutorService与Java并发工具包中的工具类,设计一个Java并发框架的分布式锁实现
Java面试题:结合单例模式与Java内存管理,设计一个线程安全的单例类?分析Java多线程工具类ExecutorService与Java并发工具包中的工具类,设计一个Java并发框架的分布式锁实现
20 0
|
17天前
|
存储 安全 Java
Java面试题:假设你正在开发一个Java后端服务,该服务需要处理高并发的用户请求,并且对内存使用效率有严格的要求,在多线程环境下,如何确保共享资源的线程安全?
Java面试题:假设你正在开发一个Java后端服务,该服务需要处理高并发的用户请求,并且对内存使用效率有严格的要求,在多线程环境下,如何确保共享资源的线程安全?
23 0