前面我们通过创建命名互斥对象的方法,使我们只能运行程序的一个实例,因为内核对象是全局的,因此我们可以检测到在已经创建命名对象的情况下判断已经有一个实例在运行。类似的,我们想到,如果能有一个全局变量,每次程序运行时使其加1,通过判断该值,我们同样可以达到这样的效果。那么如何实现全局变量呢?这里我们可以利用代码段,其定义大家可以查阅相关资料,这里就不详细解说了。下面是示例代码以及注释。
添加一个节,在.cpp文件开头加上以下几行:
#pragma data_seg("Shared") int volatile g_lAppInstance =0; #pragma data_seg()
我们来看一下上面的内容:
第一句 #pragma data_seg("Shared") 创建一个称为Shared 的新节。
第二句 int volatile g_lAppInstance =0 将 g_lAppInstance 放入Shared节中。注意此时只有将g_lAppInstance初始化,编译器才会将其放入Shared节中,否则,将放入Shared以外的节。(实际上Visual C++ 编译器提供了一个allocate 说明符,使我们可以将数据放到任何节中。)
第三句指示编译器Shared 节结束。
#pragma comment(linker,"/section:Shared,RWS")
这一句,我们使编译链接器知道我们的Shared节具有读,写,共享的属性。这是我们实现互斥运行的关键。这样我们就可以在应用程序之间的多个实例之间共享g_lAppInstance 变量。
在InitInstance() 函数中加入:
if(++g_lAppInstance>1) { AfxMessageBox("程序已经运行!"); return FALSE; }
以上代码的作用是在程序是开始对g_lAppInstancd 加1 ,如果发现其值大于1,那么显示Message Box ,并返回FALSE。(注意:在MFC中如果InitInstance返回FALSE,程序将不会被运行!)