百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Delphi基础教程图文版之多线程开篇

liuian 2025-03-04 13:07 7 浏览

这是一篇很枯燥的文章,可能很多人会觉得没有什么卵用。但是只有在搞清楚理论之后才可以完美的去实现。所以这篇文章作为多线程的开篇

其实多线程是一个很大的话题,我也仅仅停留在简单的应用,至于以后的深入只能靠自己

时间切片

在大多数支持多线程的系统中,可能有许多用户在计算机系统上同时发出请求。通常,系统中的物理处理器数量少于可能并行运行的线程数量。而此时就需要依靠时间切片完成,大多数系统都支持时间切片,也称为先发制人的多任务处理

在时间切片的系统中,线程会运行一段时间,然后被抢占; 也就是说,硬件计时器触发,导致操作系统重新评估应运行哪些线程,可能停止对当前运行的线程执行,以及运行最近未执行的其他线程。这甚至允许单处理器机器运行多个线程。在PC上,时间片往往大约是五十五毫秒。

55 毫秒的时间给人的感觉接近无感,以为是多个任务在同时运行。线程不应该改变程序的语义。他们只是改变了操作的时间。

下面几种场景我们都需要多线程的方式来完成任务

  • 进行冗长的处理:当Windows应用程序正在计算时,它无法再处理任何消息。结果,无法更新显示。
  • 进行后台处理:某些任务可能不是时间关键,但需要连续执行。
  • 执行I / O工作:磁盘或网络的I / O可能会出现不可预测的延迟。线程允许您确保I / O延迟不会延迟应用程序的不相关部分。

时间切片的概念也不小,这里不做深入讨论,仅仅产生一个认知即可

Delphi支持两种线程的启动方式,当然也有可能是 3 种

  • Win32API
  • TTHread类
  • 线程池:这种方式我没有用到,同时在掌握上面两种方式之后线程池自然也会掌握,所以我们把学习的重点放在前面两种

Delphi使得线程启动变得容易。在获取子线程执行之前,通常需要在线程中设置一些初始状态。通过创建挂起的线程(构造函数的参数),可以确保线程中的所有代码都不会执行,直到线程恢复为止。

API启动

unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls;

type
  TForm1 = class(TForm)
    btn2: TButton;
    procedure btn2Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}
{工作线程调入函数,stdcall用于多个线程排序以及系统级别调用加此关键字}
function MyFun(p:Pointer):integer;stdcall;
var
  i:integer;
begin
  for i := 0 to 500000 do
  begin
    with Form1.Canvas do
    begin
      Lock;
      {50和10是坐标X和Y}
      TextOut(50,10,IntToStr(i));
      Unlock;
      Application.ProcessMessages;
    end;
  end;
end;


{工作线程,拖动窗口时计数不会停顿,因为和主线程分开工作了}
procedure TForm1.btn2Click(Sender: TObject);
var
    {用于接收线程返回句柄,也可以用DWORD}
  ID:THandle;
begin
  {API创建线程}
  CreateThread(nil,0,@MyFun,nil,0,ID);
end;

end.

TThread

其实在Delphi中更建议使用该类完成线程相关的操作

unit UnitThread;

interface

uses
  Vcl.Forms, Vcl.Dialogs, System.SysUtils, System.Classes;

type
  TMyThread = class(TThread)
  protected
    procedure Execute; override;
  end;

implementation

uses
  UnitMain;

{ TMyThread }

procedure TMyThread.Execute;
var
  I: Integer;
begin
  FreeOnTerminate := False;
  I := 1;
  while True do begin
    if FreeOnTerminate then
      Exit;
    form1.lbl1.Caption := '线程ID:' + Self.ThreadID.ToString + ':' + I.ToString;
    TThread.Sleep(300);
    I := I + 1;
  end;

end;

end.

{启动线程的代码}

procedure TForm1.btn1Click(Sender: TObject);
begin
  Thread := TMyThread.Create(True);
  Thread.Start;
end;

通过代码可以很明显的发现 FreeOnTerminate 这玩意儿是可以控制线程的启停

OnTerminate事件

当线程真正完成执行时,会发生OnTerminate事件。它并没有在终止线程的方法被调用发生。此事件可能非常有用,因为它在主VCL线程的上下文中执行,就像传递给同步的方法一样。因此,如果一个人希望用一个在终止时自动释放自己的线程来执行一些VCL操作,那么这就是它的地方。

注意事项

要记住Execute()需要经常地检查Terminated属性的值,来确认是否要提前退出。尽管这将意味着当使用线程工作的时候,你必须关心更多的事情,但它能确保在线程结束时,能够完成必要的清除

在某些紧急情况下,你可以使用Win32 API函数 TerminateThread()来终止一个线程。但是,除非没有别的办法了,否则不要使用它。

在Delphi中还可以使用TThread类的CreateAnonymousThread函数来创建线程

相关推荐

【常识】如何优化Windows 7

优化Windows7可以让这个经典系统运行更流畅,特别是在老旧硬件上。以下是经过整理的实用优化方案,分为基础优化和进阶优化两部分:一、基础优化(适合所有用户)1.关闭不必要的视觉效果右键计算机...

系统优化!Windows 11/10 必做的十个优化配置

以下是为Windows10/11用户整理的10个必做优化配置,涵盖性能提升、隐私保护和系统精简等方面,操作安全且无需第三方工具:1.禁用不必要的开机启动项操作路径:`Ctrl+S...

最好用音频剪辑的软件,使用方法?

QVE音频剪辑是一款简单实用的软件,功能丰富,可编辑全格式音频。支持音频转换、合并、淡入淡出、变速、音量调节等,无时长限制,用户可自由剪辑。剪辑后文件音质无损,支持多格式转换,便于存储与跨设备播放,满...

Vue2 开发总踩坑?这 8 个实战技巧让代码秒变丝滑

前端开发的小伙伴们,在和Vue2打交道的日子里,是不是总被各种奇奇怪怪的问题搞得头大?数据不响应、组件传值混乱、页面加载慢……别慌!今天带来8个超实用的Vue2实战技巧,每一个都能直击痛...

Motion for Vue:为Vue量身定制的强大动画库

在前端开发中,动画效果是提升用户体验的重要手段。Vue生态系统中虽然有许多动画库,但真正能做到高性能、易用且功能丰富的并不多。今天,我们要介绍的是MotionforVue(motion-v),...

CSS view():JavaScript 滚动动画的终结

前言CSSview()方法可能会标志着JavaScript在制作滚动动画方面的衰落。如何用5行CSS代码取代50多行繁琐的JavaScript,彻底改变网页动画每次和UI/U...

「大数据」 hive入门

前言最近会介入数据中台项目,所以会推出一系列的跟大数据相关的组件博客与文档。Hive这个大数据组件自从Hadoop诞生之日起,便作为Hadoop生态体系(HDFS、MR/YARN、HIVE、HBASE...

青铜时代的终结:对奖牌架构的反思

作者|AdamBellemare译者|王强策划|Tina要点运维和分析用例无法可靠地访问相关、完整和可信赖的数据。需要一种新的数据处理方法。虽然多跳架构已经存在了几十年,并且可以对...

解析IBM SQL-on-Hadoop的优化思路

对于BigSQL的优化,您需要注意以下六个方面:1.平衡的物理设计在进行集群的物理设计需要考虑数据节点的配置要一致,避免某个数据节点性能短板而影响整体性能。而对于管理节点,它虽然不保存业务数据,但作...

交易型数据湖 - Apache Iceberg、Apache Hudi和Delta Lake的比较

图片由作者提供简介构建数据湖最重要的决定之一是选择数据的存储格式,因为它可以大大影响系统的性能、可用性和兼容性。通过仔细考虑数据存储的格式,我们可以增强数据湖的功能和性能。有几种不同的选择,每一种都有...

深入解析全新 AWS S3 Tables:重塑数据湖仓架构

在AWSre:Invent2024大会中,AWS发布了AmazonS3Tables:一项专为可扩展存储和管理结构化数据而设计的解决方案,基于ApacheIceberg开放表格...

Apache DataFusion查询引擎简介

简介DataFusion是一个查询引擎,其本身不具备存储数据的能力。正因为不依赖底层存储的格式,使其成为了一个灵活可扩展的查询引擎。它原生支持了查询CSV,Parquet,Avro,Json等存储格式...

大数据Hadoop之——Flink Table API 和 SQL(单机Kafka)

一、TableAPI和FlinkSQL是什么TableAPI和SQL集成在同一套API中。这套API的核心概念是Table,用作查询的输入和输出,这套API都是批处理和...

比较前 3 名Schema管理工具

关注留言点赞,带你了解最流行的软件开发知识与最新科技行业趋势。在本文中,读者将了解三种顶级schema管理工具,如AWSGlue、ConfluentSchemaRegistry和Memph...

大数据技术之Flume

第1章概述1.1Flume定义Flume是Cloudera提供的一个高可用的,高可靠的,分布式的海量日志采集、聚合和传输的系统。Flume基于流式架构,灵活简单。1.2Flume的优点1.可以和...