- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下线程代码,第一次就正确执行。之后,我时不时地在线程的 Execute 方法上收到 AV,例如
Debug Output: TProcesses.Execute Access violation at address 00409C8C in module 'ListenOutputDebugString.exe'. Read of address 08070610 Process ListenOutputDebugString.exe (740)
我不知道是什么生成了这个 AV...
unit Unit3;
interface
uses
Classes,
StdCtrls,
Windows,
ExtCtrls,
SysUtils,
Variants,
JvExGrids,
JvStringGrid;
type
TProcesses = class(TThread)
private
{ Private declarations }
FTimer : TTimer;
FGrid : TJvStringGrid;
FJobFinished : Boolean;
procedure OverrideOnTerminate(Sender: TObject);
procedure DoShowData;
procedure DoShowErrors;
procedure OverrideOnTimer(Sender: TObject);
protected
procedure Execute; override;
public
constructor Create(aGrid : TJvStringGrid);overload;
end;
implementation
{TProcesses }
var SharedMessage : String;
ErrsMess : String;
lp : Integer;
constructor TProcesses.Create(aGrid : TJvStringGrid);
begin
FreeOnTerminate := True;
FTimer := TTimer.Create(nil);
FTimer.OnTimer := OverrideOnTerminate;
FTimer.OnTimer := OverrideOnTimer;
FTimer.Interval := 10000;
FGrid := aGrid;
inherited Create(false);
FTimer.Enabled := true;
FJobFinished := true;
end;
procedure TProcesses.DoShowData;
var wStrList : TStringList;
wi,wj : Integer;
begin
// FMemo.Lines.Clear;
for wi := 1 to FGrid.RowCount-1 do
for wj := 0 to FGrid.ColCount-1 do
FGrid.Cells[wj,wi] := '';
try
try
wStrList := TStringList.Create;
wStrList.Delimiter := ';';
wStrList.StrictDelimiter := true;
wStrList.DelimitedText := SharedMessage;
// outputdebugstring(PChar('Processes list '+SharedMessage));
FGrid.RowCount := wStrList.Count div 4;
for wi := 0 to wStrList.Count-1 do
FGrid.Cells[(wi mod 4), (wi div 4)+1] := wStrList[wi];
Except on e:Exception do
OutputDebugString(Pchar('TProcesses.DoShowData '+e.Message));
end;
finally
FreeAndNil(wStrList);
end;
end;
procedure TProcesses.DoShowErrors;
begin
// FMemo.Lines.Add('Error '+ ErrsMess);
FGrid.Cells[1,1] := 'Error '+ ErrsMess;
ErrsMess := '';
end;
procedure TProcesses.Execute;
function EnumProcess(hHwnd: HWND; lParam : integer): boolean; stdcall;
var
pPid : DWORD;
title, ClassName : string;
begin
//if the returned value in null the
//callback has failed, so set to false and exit.
if (hHwnd=NULL) then
begin
result := false;
end
else
begin
//additional functions to get more
//information about a process.
//get the Process Identification number.
GetWindowThreadProcessId(hHwnd,pPid);
//set a memory area to receive
//the process class name
SetLength(ClassName, 255);
//get the class name and reset the
//memory area to the size of the name
SetLength(ClassName,
GetClassName(hHwnd,
PChar(className),
Length(className)));
SetLength(title, 255);
//get the process title; usually displayed
//on the top bar in visible process
SetLength(title, GetWindowText(hHwnd, PChar(title), Length(title)));
//Display the process information
//by adding it to a list box
SharedMessage := SharedMessage +
(className +' ;'+//'Class Name = ' +
title +' ;'+//'; Title = ' +
IntToStr(hHwnd) +' ;'+ //'; HWND = ' +
IntToStr(pPid))+' ;'//'; Pid = ' +
;// +#13#10;
Result := true;
end;
end;
begin
if FJobFinished then
begin
try
FJobFinished := false;
//define the tag flag
lp := 0; //globally declared integer
//call the windows function with the address
//of handling function and show an error message if it fails
SharedMessage := '';
if EnumWindows(@EnumProcess,lp) = false then
begin
ErrsMess := SysErrorMessage(GetLastError);
Synchronize(DoShowErrors);
end
else
Synchronize(DoShowData);
FJobFinished := true;
Except on e:Exception do
OutputDebugString(Pchar('TProcesses.Execute '+e.Message));
end;
end
end;
procedure TProcesses.OverrideOnTerminate(Sender: TObject);
begin
FTimer.Enabled := false;
FreeAndNil(FTimer);
end;
procedure TProcesses.OverrideOnTimer(Sender: TObject);
begin
Self.Execute;
end;
end.
最佳答案
我永远不会在线程中使用计时器。相反,我会创建一个系统事件,并使用 WaitForSingleObject
在线程的执行循环中等待指定的时间。功能。此函数将等待,直到指定对象(在本例中为事件)处于有信号状态或超时间隔已过。
原理很简单,您将在无信号状态下创建事件并将其保持在该状态直到线程将要终止。这将导致 WaitForSingleObject
每次在函数调用中指定的时间内阻塞线程执行循环时,函数都会超时。一旦您决定终止线程,您只需设置线程的终止标志(您应该尽可能多地询问该标志)并将该事件设置为有信号状态,这会导致 WaitForSingleObject
函数立即返回。
下面是一个模拟线程计时器的示例(2 秒间隔 = 2000 毫秒用作 WaitForSingleObject
函数调用中的第二个参数):
unit Unit1;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs;
type
TTimerThread = class(TThread)
private
FTickEvent: THandle;
protected
procedure Execute; override;
public
constructor Create(CreateSuspended: Boolean);
destructor Destroy; override;
procedure FinishThreadExecution;
end;
type
TForm1 = class(TForm)
procedure FormCreate(Sender: TObject);
procedure FormDestroy(Sender: TObject);
private
FTimerThread: TTimerThread;
public
{ Public declarations }
end;
var
Form1: TForm1;
implementation
{$R *.dfm}
procedure TForm1.FormCreate(Sender: TObject);
begin
ReportMemoryLeaksOnShutdown := True;
FTimerThread := TTimerThread.Create(False);
end;
procedure TForm1.FormDestroy(Sender: TObject);
begin
FTimerThread.FinishThreadExecution;
end;
{ TTimerThread }
constructor TTimerThread.Create(CreateSuspended: Boolean);
begin
inherited;
FreeOnTerminate := True;
FTickEvent := CreateEvent(nil, True, False, nil);
end;
destructor TTimerThread.Destroy;
begin
CloseHandle(FTickEvent);
inherited;
end;
procedure TTimerThread.FinishThreadExecution;
begin
Terminate;
SetEvent(FTickEvent);
end;
procedure TTimerThread.Execute;
begin
while not Terminated do
begin
if WaitForSingleObject(FTickEvent, 2000) = WAIT_TIMEOUT then
begin
Synchronize(procedure
begin
Form1.Tag := Form1.Tag + 1;
Form1.Caption := IntToStr(Form1.Tag);
end
);
end;
end;
end;
end.
关于multithreading - Delphi - 线程内定时器生成AV,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11244848/
我开始了一个项目,使用 UIImagePickerController 来捕获静态图像。由于叠加层和刚刚捕获的图像之间的交互不佳,我已经放弃使用这种简单的机制。问题如下:如果您有一个叠加层处于事件状态
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: How many styles of writing functions are there in C? 我
最近在看GSM音频编码的源码。这些代码是在 1992 年或之后编写的。 有一些奇怪的代码,例如: main P2((ac, av), int ac, char ** av) void Gsm_Code
使用 https://pypi.org/project/av/试图打开文件进行无限播放。但循环以最后一帧结束。 查找和阅读手册后,测试代码如下: (注意:这些选项预计将传递给 aiortc.contr
随着新病毒变种的发布,搜索字符串形式的数据继续增长,这引发了我的问题 - AV 引擎如何如此有效地搜索文件以查找已知签名?如果我下载了一个新文件,我的 AV 扫描仪会根据其签名迅速识别该文件是否为威胁
在应用程序按预期关闭后大约 3 到 5 秒,我收到此 AV 消息: 00073225 模块 rtl160.bpl 中的异常 EAccessViolation。模块 'rtl160.bpl' 中地址 5
在VCL中,TByteDynArray被定义为动态数组: type TByteDynArray = array of Byte; 但似乎没有完成索引边界检查: var DataBytes: Sys
我有两个引用计数类,它们相互引用实例。其中一个引用被标记为 [weak]防止创建强引用循环。 type TFoo = class(TInterfacedObject) private
我通过资源和图像对话框向我的项目添加图标,并决定放弃TIcon.LoadFromResourceName,因为它不执行任何错误检查。我编写了看似等效的代码,但没有按预期工作。 这是一个对我来说失败的测
我正在尝试使用自定义相机,并将代码从 swift 2 转换为 swift 3;我已经很完整了;但是我收到与设备有关的错误;我想要一个后置和前置摄像头,在 swift 2 之前,您可以像这样设置设备:
我想使用透明重定向(Paypal Payments Pro 软件包的功能)来处理结帐。 PayPal 文档(下面的摘录)说,当使用透明重定向时,PayPal 不会处理检查 AVS 和 CSC,把这个任
音频和视频文件可以使用AV Foundation framework播放和 Media Player framework . 当我只想播放媒体文件时,更好的选择是什么? 借助 Media Player
我将本地视频加载到新的 View Controller 中,但在完成后它会消失并立即再次弹出。我不知道是否有办法跟踪通知或什么。 这是我的代码: import UIKit import AVKit i
您好,我正在使用 AV 框架尝试访问前置摄像头... 这是我这样做的代码.. + (AVCaptureDevice *)camera { NSArray *devices = [AVCaptureD
我正在尝试使用 AVPlayer 在 iOS 上播放视频,该视频是用 zencoder 编码的。我看到的问题是播放器项目报告的持续时间是四舍五入的/不精确的。例如,视频持续时间可能是 173.134,
所以我遇到了旋转问题。我有一个 AV 摄像机设置为在 View Controller 中显示。现在我知道其中涉及很多组件,这就是为什么我只是说 AV 摄像机。我的问题是,当我旋转设备时,预览层也不随设
我的公司正在使用 Stripe API 处理信用卡。 Stripe 提供邮政编码和地址验证系统 (AVS) 检查。 AVS 将用户输入的街道号码与发卡银行的街道号码进行核对。 Stripe 返回三个结
我使用 AVFoundation 来拍照。麻烦的是,即使曝光持续时间、ISO 和白平衡的设置不变,我也会得到不同亮度的照片。手电筒、闪光灯和所有可能的稳定性都被禁用。 此问题也出现在介绍使用相机的标准
我正在尝试诱使 AV Foundation 从内存中的 mp4 文件中读取(不使用中间的写入磁盘解决方案)。我尝试了自己的自定义 URL 协议(protocol)但失败了,因为 AV Foundati
我正在尝试加载视频,在其上添加动画,然后将其导出,但动画永远不会在导出的视频中开始播放。它只是按原样显示图像“dogge_icon.png”。 我尝试了不同类型的动画,不确定我做错了什么。任何帮助将不
我是一名优秀的程序员,十分优秀!