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,如需转载请自行联系原作者

相关文章
|
3天前
|
存储 Linux C语言
c++进阶篇——初窥多线程(二) 基于C语言实现的多线程编写
本文介绍了C++中使用C语言的pthread库实现多线程编程。`pthread_create`用于创建新线程,`pthread_self`返回当前线程ID。示例展示了如何创建线程并打印线程ID,强调了线程同步的重要性,如使用`sleep`防止主线程提前结束导致子线程未执行完。`pthread_exit`用于线程退出,`pthread_join`用来等待并回收子线程,`pthread_detach`则分离线程。文中还提到了线程取消功能,通过`pthread_cancel`实现。这些基本操作是理解和使用C/C++多线程的关键。
|
6天前
|
安全 Java
【极客档案】Java 线程:解锁生命周期的秘密,成为多线程世界的主宰者!
【6月更文挑战第19天】Java多线程编程中,掌握线程生命周期是关键。创建线程可通过继承`Thread`或实现`Runnable`,调用`start()`使线程进入就绪状态。利用`synchronized`保证线程安全,处理阻塞状态,注意资源管理,如使用线程池优化。通过实践与总结,成为多线程编程的专家。
|
6天前
|
Java 开发者
告别单线程时代!Java 多线程入门:选继承 Thread 还是 Runnable?
【6月更文挑战第19天】在Java中,面对多任务需求时,开发者可以选择继承`Thread`或实现`Runnable`接口来创建线程。`Thread`继承直接但限制了单继承,而`Runnable`接口提供多实现的灵活性和资源共享。多线程能提升CPU利用率,适用于并发处理和提高响应速度,如在网络服务器中并发处理请求,增强程序性能。不论是选择哪种方式,都是迈向高效编程的重要一步。
|
6天前
|
Java 开发者
震惊!Java多线程的惊天秘密:你真的会创建线程吗?
【6月更文挑战第19天】Java多线程创建有两种主要方式:继承Thread类和实现Runnable接口。继承Thread限制了多重继承,适合简单场景;实现Runnable接口更灵活,可与其它继承结合,是更常见选择。了解其差异对于高效、健壮的多线程编程至关重要。
|
7天前
|
Java 程序员
Java多线程编程是指在一个进程中创建并运行多个线程,每个线程执行不同的任务,并行地工作,以达到提高效率的目的
【6月更文挑战第18天】Java多线程提升效率,通过synchronized关键字、Lock接口和原子变量实现同步互斥。synchronized控制共享资源访问,基于对象内置锁。Lock接口提供更灵活的锁管理,需手动解锁。原子变量类(如AtomicInteger)支持无锁的原子操作,减少性能影响。
18 3
|
6天前
|
Java
JAVA多线程深度解析:线程的创建之路,你准备好了吗?
【6月更文挑战第19天】Java多线程编程提升效率,通过继承Thread或实现Runnable接口创建线程。Thread类直接继承启动简单,但限制多继承;Runnable接口实现更灵活,允许类继承其他类。示例代码展示了两种创建线程的方法。面对挑战,掌握多线程,让程序高效运行。
|
6天前
|
Java 调度
【实战指南】Java多线程高手秘籍:线程生命周期管理,掌控程序命运的钥匙!
【6月更文挑战第19天】Java多线程涉及线程生命周期的五个阶段:新建、就绪、运行、阻塞和死亡。理解这些状态转换对性能优化至关重要。线程从新建到调用`start()`变为就绪,等待CPU执行。获得执行权后进入运行状态,执行`run()`。遇到阻塞如等待锁时,进入阻塞状态。完成后或被中断则死亡。管理线程包括合理使用锁、利用线程池、处理异常和优雅关闭线程。通过控制这些,能编写更高效稳定的多线程程序。
|
12天前
|
Java API
详细探究Java多线程的线程状态变化
Java多线程的线程状态主要有六种:新建(NEW)、可运行(RUNNABLE)、阻塞(BLOCKED)、等待(WAITING)、超时等待(TIMED_WAITING)和终止(TERMINATED)。线程创建后处于NEW状态,调用start()后进入RUNNABLE状态,表示准备好运行。当线程获得CPU资源,开始执行run()方法时,它处于运行状态。线程可以因等待锁或调用sleep()等方法进入BLOCKED或等待状态。线程完成任务或发生异常后,会进入TERMINATED状态。
|
12天前
|
存储 安全 Java
Java多线程中线程安全问题
Java多线程中的线程安全问题主要涉及多线程环境下对共享资源的访问可能导致的数据损坏或不一致。线程安全的核心在于确保在多线程调度顺序不确定的情况下,代码的执行结果始终正确。常见原因包括线程调度随机性、共享数据修改以及原子性问题。解决线程安全问题通常需要采用同步机制,如使用synchronized关键字或Lock接口,以确保同一时间只有一个线程能够访问特定资源,从而保持数据的一致性和正确性。