delphi 线程教学第七节:在多个线程时空中,把各自的代码塞到一个指定的线程时空运行
unit uJooThread;interfaceuses Classes, uFooThread;type TJooThread = class(TFooThread) public procedure Synchronize(AProc: TThreadMethod); end;implementation{ TJooThread }procedure TJooThread.Synchronize(AProc: TThreadMethod);begin ExecProcInThread(AProc); // 再设计一个等待 AProc 执行结果功能。end;end.unit uJooThread;interfaceuses Classes, SyncObjs, uFooThread, uFooList;type PSyncRec = ^TSyncRec; TSyncRec = record Method: TThreadMethod; // 这是类的方法 Proc: TThreadProcedure; // 这是匿名方法 // 本例只写了类的方法。需要匿名方法,请自行重载 Sync 与 Queue Signle: TEvent; Queue: boolean; end; TSyncRecList = class(TFooList<PSyncRec>) //用于装执行代码的 List protected procedure FreeItem(Item: PSyncRec); override; end; TJooThread = class(TFooThread) private FSyncRecList: TSyncRecList; procedure Check; public constructor Create(ACanAccessCom: boolean); destructor Destroy; override; procedure Synchronize(AProc: TThreadMethod); // 阻塞到 AProc执行完毕才返回。 procedure Queue(AProc: TThreadMethod); // 塞入线程后立即返回。 end; // 本例就是前面单节讲的知识的综合运用。 // TEvent,FooThread,FooList,全都用上了。 // 并构建了一个新的线程功能。 // 当我写完以后发现,与系统源码中, // 窗口接收 WM_NULL 消息后的处理UI操作的功能,几乎是一模一样的。 // 不同的是,本例是在线程时空,系统源码是在主线程时空。implementation{ TJooThread }procedure TJooThread.Check;var p: PSyncRec;begin FSyncRecList.Lock; // 所有要执行的代码,都在这个 List 中了。 // 此处是线程时空,故从List 中取出并执行代码即可。 try p := nil; if FSyncRecList.Count > 0 then // 每次取 List 的第一个来执行。 begin p := FSyncRecList[0]; FSyncRecList.Delete(0); end; finally FSyncRecList.Unlock; end; if Assigned(p) then begin if Assigned(p.Method) then p.Method else if Assigned(p.Proc) then p.Proc(); if not p.Queue then // 如果是阻塞,就置信号。 p.Signle.SetEvent; Dispose(p); ExecProcInThread(Check); end;end;constructor TJooThread.Create(ACanAccessCom: boolean);begin inherited; FSyncRecList := TSyncRecList.Create;end;destructor TJooThread.Destroy;begin FSyncRecList.Free; inherited;end;procedure TJooThread.Queue(AProc: TThreadMethod);var p: PSyncRec;begin FSyncRecList.Lock; try new(p); FSyncRecList.Add(p); p.Method := AProc; p.Queue := true; ExecProcInThread(Check); finally FSyncRecList.Unlock; end;end;procedure TJooThread.Synchronize(AProc: TThreadMethod);var p: PSyncRec; o: TEvent;begin FSyncRecList.Lock; try new(p); FSyncRecList.Add(p); p.Method := AProc; o := TEvent.Create(nil, true, false, ''); p.Signle := o; p.Queue := false; ExecProcInThread(Check); //触发线程启动 finally FSyncRecList.Unlock; end; o.WaitFor; // 等待 AProc 执行完毕的信号 o.Free;end;{ TSyncRecList }procedure TSyncRecList.FreeItem(Item: PSyncRec);begin inherited; if Assigned(Item.Signle) then Item.Signle.Free; Dispose(Item);end;end.delphi 线程教学第七节:在多个线程时空中,把各自的代码塞到一个指定的线程时空运行的更多相关文章
- delphi 线程教学第五节:多个线程同时执行相同的任务
第五节:多个线程同时执行相同的任务 1.锁 设,有一个房间 X ,X为全局变量,它有两个函数 X.Lock 与 X.UnLock; 有如下代码: X.Lock; 访问资源 P; ...
- delphi 线程教学第四节:多线程类的改进
第四节:多线程类的改进 1.需要改进的地方 a) 让线程类结束时不自动释放,以便符合 delphi 的用法.即 FreeOnTerminate:=false; b) 改造 Create 的参数 ...
- delphi 线程教学第六节:TList与泛型
第六节: TList 与泛型 TList 是一个重要的容器,用途广泛,配合泛型,更是如虎添翼. 我们先来改进一下带泛型的 TList 基类,以便以后使用. 本例源码下载(delphi XE8版本) ...
- delphi 线程教学第二节:在线程时空中操作界面(UI)
第二节:在线程时空中操作界面(UI) 1.为什么要用 TThread ? TThread 基于操作系统的线程函数封装,隐藏了诸多繁琐的细节. 适合于大部分情况多线程任务的实现.这个理由足够了吧 ...
- delphi 线程教学第一节:初识多线程
第一节:初识多线程 1.为什么要学习多线程编程? 多线程(多个线程同时运行)编程,亦可称之为异步编程. 有了多线程,主界面才不会因为耗时代码而造成“假死“状态. 有了多线程,才能使多个任务同时 ...
- delphi 线程教学第三节:设计一个有生命力的工作线程
第三节:设计一个有生命力的工作线程 创建一个线程,用完即扔.相信很多初学者都曾这样使用过. 频繁创建释放线程,会浪费大量资源的,不科学. 1.如何让多线程能多次被复用? 关键是不让代码退出 ...
- CUDA:Supercomputing for the Masses (用于大量数据的超级计算)-第七节
第七节:使用下一代CUDA硬件,快乐加速度 原文链接 Rob Farber 是西北太平洋国家实验室(Pacific Northwest National Laboratory)的高级科研人员.他在多个 ...
- 基于Extjs的web表单设计器 第七节——取数公式设计之取数公式的使用
基于Extjs的web表单设计器 基于Extjs的web表单设计器 第一节 基于Extjs的web表单设计器 第二节——表单控件设计 基于Extjs的web表单设计器 第三节——控件拖放 基于Extj ...
- JAVA 从GC日志分析堆内存 第七节
JAVA 从GC日志分析堆内存 第七节 在上一章中,我们只设置了整个堆的内存大小.但是我们知道,堆又分为了新生代,年老代.他们之间的内存怎么分配呢?新生代又分为Eden和Survivor,他们的比 ...
随机推荐
- 我对let和const理解
let和const是es6新出的两种变量声明的方式,接下来我来分别针对这两个,聊一聊. let let它的出现,我认为主要是解决了块级作用域的需求.因为js以前本身是没有什么块级作用域的概念的(顶 ...
- requests+正则表达式提取猫眼电影top100
#requests+正则表达式提取猫眼电影top100 import requests import re import json from requests.exceptions import Re ...
- PHP 抓取网页内容的几个函数
<?php //获取所有内容url保存到文件 function get_index($save_file, $prefix="index_"){ $count = 68; $ ...
- axios介绍与使用说明 axios中文文档
本周在做一个使用vuejs的前端项目,访问后端服务使用axios库,这里对照官方文档,简单记录下,也方便大家参考. Axios 是一个基于 Promise 的 HTTP 库,可以用在浏览器和 node ...
- 用PHP如何实现这种乘法口诀表?
用PHP如何实现这种乘法口诀表? 1x1=1 ,1x2=2 ,1x3=3 ,.....,1x9=9 2x2=4 ,2x3=6 ,......,2x9=18 ........ ...... 8x8=64 ...
- Unity依赖注入
一.简介 Unity是一个轻量级的可扩展的依赖注入容器,支持构造函数,属性和方法调用注入.Unity可以处理那些从事基于组件的软件工程的开发人员所面对的问题.构建一个成功应用程序的关键是实现非常松散的 ...
- [LeetCode] 01 Matrix 零一矩阵
Given a matrix consists of 0 and 1, find the distance of the nearest 0 for each cell. The distance b ...
- 实验吧_貌似有点难(php代码审计)&头有点大
二话不说先贴代码 <?php function GetIP(){ if(!empty($_SERVER["HTTP_CLIENT_IP"])) $cip = $_SERVER ...
- [SDOI 2008]沙拉公主的困惑
Description 大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有钞票编号范围为1到N的阶乘,但是,政府只发行编号与M!互质的钞票.房地产第一大户沙拉公主决定预测一下大富翁国现 ...
- permu(变态考试题)
题目描述 给定一个严格递增的序列T,求有多少个T的排列S满足:∑min(T[i],S[i])=k 输入输出格式 输入格式: 第一行两个数n,k 第二行n个数,表示T 输出格式: 一个正整数表示答案,答 ...