У меня много процессов в приложении в стиле конвейера. Каждый раз, когда я запускаю приложение, меняются количество и порядок процессов, составляющих конвейер.
Я намерен запустить их через главный командный файл, однако я хотел бы запускать их без окна консоли. У меня может быть одна консоль для партии, но я бы не стал загромождать пользовательский опыт более чем 9 различными консольными окнами.
Есть ли способ добиться этого без установки службы? Или, возможно, временное обслуживание (если это возможно)?
Спасибо!
Если это делается в пакетном файле, разве вы не можете использовать START /B
?
Что ж, на мой взгляд, вам придется заняться развитием. Вы можете сделать приложение-пусковую установку без окна (информации по этому поводу много).
В вашем приложении запуска вы вызовете какой-то вариант Windows API CreateProcess. Вы можете попробовать поиграть с флагом CREATE_NO_WINDOW в параметре CreateProcess dwCreationFlags. Прочтите документацию в MSDN, чтобы узнать об ограничениях.
Вот код на VC ++, который я нашел в Интернете, я его не тестировал, но идея есть:
//-------------------------------------------------------------
//
// File: Launcher.cpp
//
// Copyright 2005 (c) by Euphonix, Inc.
//
// Description:
//
// Simple shell application for XPE. Reads a registry entry
// (set via target designer) to find an init file. Reads the
// init file to find an app to launch and working dir to use.
// Launches the app and waits for the launched process to
// terminate.
//
// If failure occurs anywhere along the way, launches an XP
// command window as a failsafe.
//
// Author: Fritz Mueller
//
// Creation Date: 8/3/05
//
// Implementation Notes:
//
//-------------------------------------------------------------
#define WINVER 0x0501
#include <afxwin.h>
#include <tchar.h>
#include <sstream>
using namespace std;
typedef basic_ostringstream<TCHAR> tostringstream;
typedef basic_string<TCHAR> tstring;
class LauncherErr
{
public:
LauncherErr(DWORD iCode, const tstring &iDesc) : mCode(iCode), mDesc(iDesc)
{}
DWORD mCode;
tstring mDesc;
};
DWORD SpawnProcess(
const tstring &cmdline,
const tstring &workingdir,
DWORD creationFlags)
{
DWORD result;
BOOL success;
STARTUPINFO si;
ZeroMemory(&si, sizeof(si));
PROCESS_INFORMATION pi;
success = CreateProcess(
NULL, (LPTSTR)cmdline.c_str(), NULL, NULL, FALSE, creationFlags, NULL,
workingdir.empty() ? NULL : workingdir.c_str(), &si, &pi
);
if (!success) throw LauncherErr(GetLastError(), _T("Could not create
process."));
result = WaitForSingleObject(pi.hProcess, INFINITE);
if (result == WAIT_FAILED) throw LauncherErr(GetLastError(), _T("Process
wait failed."));
DWORD exitcode;
success = GetExitCodeProcess(pi.hProcess, &exitcode);
if (!success) throw LauncherErr(GetLastError(), _T("Could not retrieve
process exit code."));
CloseHandle(pi.hProcess);
CloseHandle(pi.hThread);
return exitcode;
}
int APIENTRY _tWinMain(
HINSTANCE hInstance,
HINSTANCE hPrevInstance,
LPTSTR lpCmdLine,
int nCmdShow)
{
DWORD result;
try {
HKEY key;
result = RegOpenKey(HKEY_LOCAL_MACHINE,
_T("Software\\Euphonix\\LauncherShell\\"), &key);
if (result != ERROR_SUCCESS) throw LauncherErr(GetLastError(), _T("Could
not open launcher registry key."));
DWORD valuetype;
TCHAR initpath[MAX_PATH];
DWORD initpathsize = sizeof(initpath);
result = RegQueryValueEx(key, _T("InitFile"), NULL, &valuetype,
(LPBYTE)initpath, &initpathsize);
if (result != ERROR_SUCCESS) throw LauncherErr(GetLastError(), _T("Could
not retrieve init file registry value."));
TCHAR cmdline[MAX_PATH];
DWORD cmdlinesize = MAX_PATH;
cmdlinesize = GetPrivateProfileString(_T("application"), _T("cmdline"),
NULL, cmdline, cmdlinesize, initpath);
if (cmdlinesize == 0) throw LauncherErr(GetLastError(), _T("Could not
retrieve command."));
TCHAR workingdir[MAX_PATH];
DWORD workingdirsize = MAX_PATH;
workingdirsize = GetPrivateProfileString(_T("application"),
_T("workingdir"), _T(""), workingdir, workingdirsize, initpath);
result = SpawnProcess(cmdline, workingdir, DETACHED_PROCESS);
}
catch(const LauncherErr &err) {
tostringstream str;
str << _T("cmd /k echo Euphonix Launcher Error (") << err.mCode << _T("):
") << err.mDesc << endl;
result = SpawnProcess(str.str(), _T(""), CREATE_NEW_CONSOLE);
}
return (result == ERROR_SUCCESS) ? 0 : -1;
}
Надеюсь это поможет.