C语言实现在windows服务中新建进程的方法_C 语言

本文实例讲述了C语言实现在windows服务中新建进程的方法。分享给大家供大家参考。具体如下:

运行环境:visual stdio 2008

文件名:testService.c

#include <windows.h>
#include <stdio.h>
#include <time.h>
#include <tchar.h>
HANDLE hMutex;
SERVICE_STATUS  ServiceStatus;
SERVICE_STATUS_HANDLE ServiceStatusHandle;
PROCESS_INFORMATION pi;
//Service Control Handler Function
void WINAPI CmdControl(DWORD dwCode)
{
  switch(dwCode)
  {
  case SERVICE_CONTROL_PAUSE:
    ServiceStatus.dwCurrentState = SERVICE_PAUSED;
    break;
  case SERVICE_CONTROL_CONTINUE:
    ServiceStatus.dwCurrentState = SERVICE_RUNNING;
    break;
  case SERVICE_CONTROL_STOP:
    WaitForSingleObject(hMutex,INFINITE);
    //if (WaitForSingleObject(pi.hProcess, 5000) != WAIT_OBJECT_0)
    TerminateProcess(pi.hProcess,0); //由于我自己在服务里建了一个进程,所以当服务停止时需要将建的进程也停掉
    ServiceStatus.dwCurrentState = SERVICE_STOPPED;
    ServiceStatus.dwWin32ExitCode = 0;
    ServiceStatus.dwCheckPoint = 0;
    ServiceStatus.dwWaitHint  = 0;
    if(SetServiceStatus(ServiceStatusHandle,&ServiceStatus)==0)
    {
      printf("SetServiceStatus in CmdControl in Switch Error !\n");
    }
    return ;
  case SERVICE_CONTROL_INTERROGATE:
    break;
  default:
    break;
  }
  if(SetServiceStatus(ServiceStatusHandle,&ServiceStatus)==0)
  {
    printf("SetServiceStatus in CmdControl out Switch Error !\n");
  }
  return ;
}
int WriteToLog(char* str)
{
 FILE* log;
 log = fopen("dma_ws.log", "a+");
 if (log == NULL)
  return -1;
 fprintf(log, "%s\n", str);
 fclose(log);
 return 0;
}
//Service ServiceMain Function
void WINAPI CmdStart(DWORD dwArgc,LPTSTR *lpArgv)
{
  ServiceStatus.dwServiceType    = SERVICE_WIN32;
  ServiceStatus.dwCurrentState   = SERVICE_START_PENDING;
  ServiceStatus.dwControlsAccepted  = SERVICE_ACCEPT_STOP
             | SERVICE_ACCEPT_PAUSE_CONTINUE;
  ServiceStatus.dwServiceSpecificExitCode = 0;
  ServiceStatus.dwWin32ExitCode   = 0;
  ServiceStatus.dwCheckPoint    = 0;
  ServiceStatus.dwWaitHint    = 0;
  ServiceStatusHandle=RegisterServiceCtrlHandler(TEXT("ntkrnl"),CmdControl); //注册控制响应程序
  if (ServiceStatusHandle == 0)
  {
    printf("RegisterServiceCtrlHandler Error !\n");
    return ;
  }
  ServiceStatus.dwCurrentState = SERVICE_RUNNING;
  ServiceStatus.dwCheckPoint = 0;
  ServiceStatus.dwWaitHint  = 0;
  if(SetServiceStatus(ServiceStatusHandle,&ServiceStatus)==0)
  {
    printf("SetServiceStatus in CmdStart Error !\n");
    return ;
  }
  // 接下来可以做你要做的事了,我这里新建了一个进程
  STARTUPINFO si;
  ZeroMemory( &si, sizeof(si) );
  si.cb = sizeof(si);
  si.wShowWindow = true;
  ZeroMemory( π, sizeof(pi) );
  char buf[100] ={0};
  TCHAR szCommandLine[] = TEXT("C:\\Program Files (x86)\\IronPython 2.7.1\\ipy.exe C:\\DXMonitorSystem\\DXHttpServer.py");
  TCHAR cwd[] = TEXT("C:\\DXMonitorSystem");
  if (!CreateProcess(NULL, //在服务运行后新建了一个进程,实际的工作都由新建的进程完成
   szCommandLine,
   NULL,
   NULL,
   FALSE,
   0,
   NULL,
   cwd, //这个参数必不可少,而且要是绝对路径,不然服务会找不到创建新进程所需文件所在目录
   &si,
   π))
  {
   sprintf(buf, "CreateProcess failed (%d).\n", GetLastError());
   WriteToLog(buf);
  }
  else
  {
   // 不使用的句柄最好关掉
   //CloseHandle(pi.hThread);
   //CloseHandle(pi.hProcess);
   sprintf(buf, "new process ID:%d\n",pi.dwProcessId);
   sprintf(buf+strlen(buf), "new process master thread ID:%d\n",pi.dwThreadId);
   WriteToLog(buf);
  }
  WriteToLog("hello,world\n");
  return ;
}
int main()
{
  SERVICE_TABLE_ENTRY DispatchTable[] =
  {
    {TEXT("ntkrnl"),CmdStart},
    {NULL ,NULL }
  };
  StartServiceCtrlDispatcher(DispatchTable);
  //注意:CmdStart函数
  return 0;
} 

使用方法:

安装服务:sc create testService binpath= c:\testService.exe

删除服务: sc delete testService

希望本文所述对大家的C语言程序设计有所帮助。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索c语言
, 进程
windows服务
用c语言实现进程调度、c语言实现进程调度、进程调度算法c语言、c语言新建工程、c语言创建进程,以便于您获取更多的相关知识。

时间: 2024-11-20 20:17:58

C语言实现在windows服务中新建进程的方法_C 语言的相关文章

python实现在windows服务中新建进程的方法

  本文实例讲述了python实现在windows服务中新建进程的方法.分享给大家供大家参考.具体实现方法如下: 需要安装的软件:python和pywin32,我这里装的分别是python-2.6.amd64.pywin32-217.win-amd64-py2.6 文件名:dma_ws.py ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 #!python

C语言实现清空指定文件夹中所有文件的方法_C 语言

本文实例讲述了C语言实现清空指定文件夹中所有文件的方法.分享给大家供大家参考.具体分析如下: 最近笔者在做一个有关计算机视觉的项目,需要对提前的视频帧进行实验,当数据量很大且文件夹中的子文件夹和文件很多时,手工删除这些文件不现实,笔者今天写了一个程序,通过机器自动删除所有相关文件,十分快速,删除时间几乎可以不计. 代码如下,仅供参考. #include "iostream.h" //代码如需调试,只需将改成""即可 #include "string.h&q

C++二分法在数组中查找关键字的方法_C 语言

本文实例讲述了C++二分法在数组中查找关键字的方法.分享给大家供大家参考.具体如下: /* 此程序演示了二分法查找算法(针对按从小到大排列的数组)的实现. */ #include <iostream> using namespace std; /* 功能: 实现数组的二分法查找(只算法只适合按从小到大排列的数组) 返回值:关键字在数组中的下标, 返回-1表示未找到 a[]: 要搜索的数组 len: 数组元素个数 key: 要查找的关键字 */ int binSearch(int a[], in

利用C语言替换文件中某一行的方法_C 语言

文件中存贮的内容如下所示: 11 1122 0 1122 * * 0 0 22 222 0 222 * * 0 0 33 333 0 333 * * 0 0 通过使用下面的几个函数,fopen,fprintf,fscanf,fseek,ftell . 具体的函数函数原型如下所示: FILE*fopen(const char*filename,const char *mode); int fprintf(FILE*stream,const char *format,...) int fscanf(

MFC对话框中添加状态栏的方法_C 语言

本文实例讲述了MFC对话框中添加状态栏的方法.分享给大家供大家参考.具体如下: 1.在对话框的dlg实现类里添加成员变量: CXTPStatusBar m_wndStatusBar; //状态栏(或者是CStatusBar) //在OnInitDialog方法中初始化: static UINT indicators[] = { ID_SEPARATOR, // status line indicator ID_INDICATOR_CAPS, ID_INDICATOR_NUM, ID_INDICA

C语言实现最长递增子序列问题的解决方法_C 语言

本文实例展示了C语言实现最长递增子序列问题的解决方法.分享给大家供大家参考.具体方法如下: 问题描述: 给定一个序列,找出其最长递增子序列长度. 比如 输入 1 3 7 5 输出 3 算法解决思路: 利用动态规划的思想,以序列的每个点最为最右端,找出每个点作为最右端时的子序列长度的最大值,即问题的求解.因此,在计算前面的每个点的时候,将其结果保存下来,后面的点与前面的点的数值进行比较,如果大,则在其长度基础上加1,并且找出所有可能情况下最长的保存为当前点的长度.形成递归. 具体实现代码如下: #

C语言左旋转字符串与翻转字符串中单词顺序的方法_C 语言

左旋转字符串题目: 定义字符串的左旋转操作:把字符串前面的若干个字符移动到字符串的尾部. 如把字符串 abcdef  左旋转 2  位得到字符串 cdefab.请实现字符串左旋转的函数. 要求时间对长度为 n  的字符串操作的复杂度为 O(n),辅助内存为 O(1). 分析: 网上看到解法很多种,就不详细说明了. 我采用的是数组不对称的交换时间复杂度应该是O(n). 代码实现(GCC编译通过): #include "stdio.h" #include "stdlib.h&qu

C++程序中启动线程的方法_C 语言

 C++11 引入一个全新的线程库,包含启动和管理线程的工具,提供了同步(互斥.锁和原子变量)的方法,我将试图为你介绍这个全新的线程库. 如果你要编译本文中的代码,你至少需要一个支持 C++11 的编译器,我使用的是 GCC 4.6.1,需要使用 -c++0x 或者 -c++11 参数来启用 C++11 的支持. 启动线程 在 C++11 中启动一个线程是非常简单的,你可以使用 std:thread 来创建一个线程实例,创建完会自动启动,只需要给它传递一个要执行函数的指针即可,请看下面这个 He

使用C语言求二叉树结点的最低公共祖先的方法_C 语言

算法分析 我们直接来分析O(n)的算法. 比如求节点F和节点H的最低公共祖先,先求出从根节点A到F的路径,再求出A到H的路径,那么最后一个相同的节点就是最低公共祖先.A->B->D->F和A->B->E->H,最后相同的节点事B,所以最低公共祖先是B节点.求根节点到指定节点的算法先前已经更新过了,复杂度是O(n),所以总的时间复杂度是O(n). 条件细化: (1)树如果是二叉树,而且是二叉排序树.              这中条件下可以使用二叉排序树的搜索功能找到最低