我是靠谱客的博主 狂野冷风,最近开发中收集的这篇文章主要介绍win32 linux 只启动一个进程,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

windows  OnInitDialog

    HANDLE m_hMutex = ::CreateMutex(NULL, TRUE, _T("SZSEL2Collecter"));
    if (GetLastError() == ERROR_ALREADY_EXISTS)
    {
        if (MessageBox(_T("SZSEL2Collecter采集程序已正在运行,是否再次运行?"), _T("警告"), MB_YESNO) == IDNO)
        {
            PostQuitMessage(0);
            CloseHandle(m_hMutex);
            return TRUE;
        }
    }

// Linux 下面用文件锁实现进程只能打开单个实例,win32 用createMutex实现。
#include <fcntl.h>
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <errno.h>
#include <string.h>


#define TestLockfile "OneInstance.pid"
int ValidProcessRun(char* lockfile)
{
    int fd;
    fd = open(lockfile, O_CREAT | O_RDWR, S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);
    if(fd < 0){
        printf("can't open the lock file: %s n",lockfile);
        return -1;
    }
    // 进行加锁操作
    struct flock f1;
    f1.l_type = F_WRLCK; // 设置为唯一写锁,如果是同一个进程不会失败,会替换原来的锁。
    f1.l_start = 0;
    f1.l_whence = SEEK_SET;
    f1.l_len = 0; // 设置锁的大小为为整个文件
    if(fcntl(fd, F_SETLK, &f1) < 0){
        if(errno == EACCES || errno == EAGAIN){
            printf("The process has only one instance.n");
            close(fd);
            return -1;
        }
        printf("can't lock.n");
        return -1;
    }
    // 截断文件
    ftruncate(fd, 0);
    char buf[32];
    sprintf(buf, "%ld", (long)getpid());
    write(fd, buf, strlen(buf)+1);
    return 0;
}

int main(){
  if(ValidProcessRun(TestLockfile) == -1) //进程如果启动就报进程只能启动一次
      exit(1);
  while(1){
    printf("Runing...n");
    sleep(1);
  }
  return 0;
}

最后

以上就是狂野冷风为你收集整理的win32 linux 只启动一个进程的全部内容,希望文章能够帮你解决win32 linux 只启动一个进程所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(70)

评论列表共有 0 条评论

立即
投稿
返回
顶部