zoukankan
html css js c++ java
防止再次运行同一个应用程序
防止同时打开多个应用程序的实例,也就是同时只有一个程序在运行,再运行同一个程序时,会自动关闭,以下代码放在项目的.dpr(项目文件)中的Application.Initialize;上面。
代码如下
var
hMutex: DWORD;
Ret: Integer;
{以上代码要放在begin..end上}
hMutex :
=
0
;
try
hMutex :
=
CreateMutex(nil, False,
'
eShapeOfClient
'
);
//
TRUE 标明该进程拥有此 Mutex 对象eShapeOfClient为自己的程序文件名或自己定义的任意名称
Ret :
=
GetLastError;
if
(Ret
=
ERROR_ALREADY_EXISTS) then
//
Mutex 对象是否存在
begin
ReleaseMutex(hMutex);
Application.Terminate;
//
退出程序
end
else
if
hMutex
=
ERROR_INVALID_HANDLE then
begin
InfoDlg(
'
此程序正在运行,关闭后请重新再试!
'
);
//InfoDlg函数是自己定义的,通常用MessgeBox来代替
Application.Terminate;;
end;
finally
ReleaseMutex(hMutex);
end;
以上代码没有任何问题,但在运行第二个程序关闭时,也就是Application.Terminate; 会有屏闪,如果改成Exit;好像没有问题。
查看全文
相关阅读:
NFS原理
linux NFS配置案例
centos swap分区
git常用命令
MHA介绍和基础、原理、架构、工具介绍
mysql5.7.26部署MHA
mysql5.7.26 基于GTID的主从复制环境搭建
MHA监控进程异常退出(MHA版本:0.56)
mysql 主从 Last_IO_Errno错误代码说明
mysql 在gtid环境下缺少一部分binlog部署从库
原文地址:https://www.cnblogs.com/sonicit/p/827382.html
最新文章
Java JVM
Java高并发程序设计
win8找到程序员计算器
scala中json操作
spark资源调控
spark算子整理
scala使用回顾
maven使用
IDEA使用技巧
mongo问题汇总
热门文章
python技巧
sparksql读取hive数据报错:java.lang.RuntimeException: serious problem
spark-sql使用笔记
mysql之InnoDb引擎与MyISAM引擎对比
mysql细说show slave status参数详解(最全)
mysql主从复制原理
判断我们的服务器是物理机还是虚拟机
docker资源隔离实现方式
Centos7基础优化操作项
docker基础命令
Copyright © 2011-2022 走看看