程序运行实例数量的控制——大全篇

原创 2004年03月29日 10:31:00

 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

    经常会碰到有人问如何保证程序只运行一个实例,原来我也零碎的给过两三个方法,今天干脆来个大总结,希望对大家在做程序设计的时候有所帮助。

 

    一个程序只运行一个实例(或限制实例数量)通常可以采用如下方法:

 

1FindWindow <窗口标题>

    通过查找窗口标题来确定上一实例是否正在运行,不适合窗口标题动态变化的程序。

 

2FindWindow <任务栏按纽标题>

    通过查找任务栏按纽标题来确定上一实例是否正在运行,不适合按纽标题动态变化的程序(如Winamp)。通常情况下,该方法还是优先考虑,因为按纽标题是一般是固定的。

 

3Window Property

    将某个数据(可以是字符串或句柄)通过SetProp加入到指定窗口的property list,程序运行时枚举窗口并检查该数据是否存在来确定上一实例是否正在运行。

 

4)全局Atom

    将某个特定字符串通过GlobalAddAtom加入全局原子表(Global Atom Table),程序运行时检查该串是否存在来确定上一实例是否正在运行。该方法有个局限,就是程序终止前必须显式调用GlobalDeleteAtom来释放atom,否则该atom不会自动释放,如果程序运行时意外终结了,那么下一个实例就无法正常执行。早期版本的realplayer就存在这个现象,不知道是不是采用了该方法。

 

5Mutex/Event/Semaphore

    通过互斥对象/信号量/事件等线程同步对象来确定实例是否存在,在NT下要注意权限问题(SID)。

 

6DLL全局共享区域

    VC下的DLL工程可以通过下面代码来建立一个进程间共享数据段:

    #pragma data_seg(".share")

    //shared for all processes that attach to the dll

    DWORD dllgs_dwRunCount = 1; //一定要在这里对变量进行初始化,否则工夫白做!

    #pragma data_seg()

    #pragma comment(linker,"/section:.share,rws")

   

    导出3个函数,分别为:

    DWORD IncRunCount(void); //运行计数器加1,返回计数器结果

    DWORD DecRunCount(void); //运行计数器减1,返回计数器结果

    DWORD GetRunCount(void); //取当前运行计数器

   

    由于DLL全局共享段在映射到各个进程地址空间时仅会被初始化一次,并且是在首次被windows加载时,所以利用该共享段数据就能对程序实例进行可靠计数。

 

7)内存映射文件(File Mapping)

    通过把程序实例信息(如窗口句柄、计数器等等)放置到跨进程的内存映射文件,同样可以控制程序实例运行的数量,道理与DLL全局共享区域类似。

 

8)其它

    曾经见过有人通过注册表、磁盘文件等途径来处理实例控制问题,但由于这些参考对象均为非易失性资源,在碰到程序非正常结束且没有清除实例标识时相当麻烦,真正使用起来具有很大的局限性。

 

    总结:前面三种方法适用于拥有窗体的程序,而后面几种则没有这个限制,但相对而言后者实现起来较复杂。不管采用哪种方法,参考对象均必须具有可共享、跨进程、易失性、重启自复位等必要性质。

 

java多线程Semaphore使用实例,细化粒度控制并发数量

1、Semaphore:线程协同类,用来控制线程并发数量,并且可以更加细粒度的进行控制,因为真正被控制最大并发的代码放到了acquire和release之间。 2、主要方法: //初始值 co...
  • javaloveiphone
  • javaloveiphone
  • 2017年02月07日 11:33
  • 924

Java自定义线程池和线程总数控制

1 概述 池化是常见的思想,线程池是非常典型的池化的实现,《Java并发编程实战》也大篇幅去讲解了Java中的线程池。本文实现一个简单的线程池。 2 核心类 【1】接...
  • qq_24273557
  • qq_24273557
  • 2017年03月10日 14:35
  • 558

WCF 第五章 控制并发实例的数量

默认情况下,WCF 宿主将会启动尽可能多的实例来处理请求消息。如果一个服务的实例和并发行为并没有确定,WCF将会为每个进入的请求创建一个服务实例同时将按照需要分配线程来反应请求。总体来说这是一个对性能...
  • nieweiking
  • nieweiking
  • 2016年05月10日 09:45
  • 1087

线程池控制并发数量

直接限定线程池的最大最小线程数也可以, 但会影响程序其它地方用到线程池的地方,因为线程池的设置是全局的。...
  • yenange
  • yenange
  • 2016年11月10日 14:21
  • 868

02-大话程序猿眼里的高并发架构

原文链接: https://blog.thankbabe.com/2016/09/14/high-concurrency-scheme/ 高并发经常会发生在有大活跃用户量,用户高聚集的业务场景...
  • lmjy102
  • lmjy102
  • 2017年11月18日 21:15
  • 228

mapreduce中控制mapper的数量

很多文档中描述,Mapper的数量在默认情况下不可直接控制干预,因为Mapper的数量由输入的大小和个数决定。在默认情况下,最终input占据了多少block,就应该启动多少个Mapper。如果输入的...
  • wxc20062006
  • wxc20062006
  • 2014年09月30日 11:39
  • 323

控制SQL返回数量

Sql Server : Sql代码 select top X * from table_name --查询前X条记录,可以改成需要的数字。select top n * from (sel...
  • zheng558888
  • zheng558888
  • 2013年11月13日 17:59
  • 1327

mapreduce中控制mapper的数量

很多文档中描述,Mapper的数量在默认情况下不可直接控制干预,因为Mapper的数量由输入的大小和个数决定。在默认情况下,最终input占据了多少block,就应该启动多少个Mapper。如果输入的...
  • lhy66
  • lhy66
  • 2015年04月07日 21:36
  • 446

mapreduce中MAP数量如何控制?

一、果断先上结论 1.如果想增加map个数,则设置mapred.map.tasks 为一个较大的值。 2.如果想减小map个数,则设置mapred.min.split.size 为一个较大的值。 3....
  • levy_cui
  • levy_cui
  • 2016年10月28日 11:05
  • 315

Hadoop中控制Map的数量

hadooppathinputstringapi文档 目录(?)[-] 深度分析如何在Hadoop中控制Map的数量 InputFormat介绍FileInputFormat...
  • qingmu0803
  • qingmu0803
  • 2014年09月26日 19:47
  • 377
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:程序运行实例数量的控制——大全篇
举报原因:
原因补充:

(最多只允许输入30个字)