다음을 통해 공유


SHELLEXECUTEINFOA 구조체(shellapi.h)

ShellExecuteEx사용하는 정보를 포함합니다.

통사론

typedef struct _SHELLEXECUTEINFOA {
  DWORD     cbSize;
  ULONG     fMask;
  HWND      hwnd;
  LPCSTR    lpVerb;
  LPCSTR    lpFile;
  LPCSTR    lpParameters;
  LPCSTR    lpDirectory;
  int       nShow;
  HINSTANCE hInstApp;
  void      *lpIDList;
  LPCSTR    lpClass;
  HKEY      hkeyClass;
  DWORD     dwHotKey;
  union {
    HANDLE hIcon;
    HANDLE hMonitor;
  } DUMMYUNIONNAME;
  HANDLE    hProcess;
} SHELLEXECUTEINFOA, *LPSHELLEXECUTEINFOA;

회원

cbSize

형식: DWORD

필수. 이 구조체의 크기(바이트)입니다.

fMask

형식: ULONG

다른 구조체 멤버의 내용과 유효성을 나타내는 다음 값 중 하나 이상의 조합입니다.

SEE_MASK_DEFAULT(0x00000000) 기본값을 사용합니다.
SEE_MASK_CLASSNAME(0x00000001) lpClass 멤버에서 지정한 클래스 이름을 사용합니다. SEE_MASK_CLASSKEY 및 SEE_MASK_CLASSNAME 모두 설정되면 클래스 키가 사용됩니다.
SEE_MASK_CLASSKEY(0x00000003) hkeyClass 멤버가 지정한 클래스 키를 사용합니다. SEE_MASK_CLASSKEY 및 SEE_MASK_CLASSNAME 모두 설정되면 클래스 키가 사용됩니다.
SEE_MASK_IDLIST(0x00000004) lpIDList 멤버가 지정한 항목 식별자 목록을 사용합니다. lpIDList 멤버는 ITEMIDLIST 구조를 가리킵니다.
SEE_MASK_INVOKEIDLIST(0x0000000C) 선택한 항목의 바로 가기 메뉴 처리기IContextMenu 인터페이스를 사용합니다. lpFile 사용하여 파일 시스템 경로로 항목을 식별하거나 lpIDList PIDL로 항목을 식별합니다. 이 플래그를 사용하면 애플리케이션에서 ShellExecuteEx 사용하여 레지스트리에 나열된 정적 동사 대신 바로 가기 메뉴 확장에서 동사를 호출할 수 있습니다.
참고: SEE_MASK_INVOKEIDLIST SEE_MASK_IDLIST 재정의하고 의미합니다.
SEE_MASK_ICON(0x00000010) hIcon 멤버가 지정한 아이콘을 사용합니다. 이 플래그는 SEE_MASK_HMONITOR 함께 사용할 수 없습니다.
참고: 이 플래그는 Windows XP 및 이전 버전에서만 사용됩니다. Windows Vista에서 무시됩니다.
SEE_MASK_HOTKEY(0x00000020) dwHotKey 멤버가 지정한 바로 가기 키를 사용합니다.
SEE_MASK_NOCLOSEPROCESS(0x00000040) hProcess 멤버가 프로세스 핸들을 수신함을 나타내는 데 사용합니다. 이 핸들은 일반적으로 애플리케이션에서 ShellExecuteEx 사용하여 만든 프로세스가 종료되는 시기를 확인할 수 있도록 하는 데 사용됩니다. DDE 대화를 통해 실행이 충족되는 경우와 같은 경우에 핸들이 반환되지 않습니다. 호출 애플리케이션은 더 이상 필요하지 않을 때 핸들을 닫습니다.
SEE_MASK_CONNECTNETDRV(0x00000080) 공유의 유효성을 검사하고 드라이브 문자에 연결합니다. 이렇게 하면 연결이 끊긴 네트워크 드라이브를 다시 연결할 수 있습니다. lpFile 멤버는 네트워크에 있는 파일의 UNC 경로입니다.
SEE_MASK_NOASYNC(0x00000100) 반환하기 전에 실행 작업이 완료되기를 기다립니다. 이 플래그는 비동기 활성화를 초래할 수 있는 ShellExecute 양식을 사용하는 호출자(예: DDE)에서 사용하고 백그라운드 스레드에서 실행될 수 있는 프로세스를 만들어야 합니다. (참고: ShellExecuteEx 호출자의 스레딩 모델이 Apartment가 아닌 경우 기본적으로 백그라운드 스레드에서 실행됩니다.) 백그라운드 스레드에서 이미 실행 중인 프로세스에서 ShellExecuteEx 대한 호출은 항상 이 플래그를 전달해야 합니다. 또한 ShellExecuteEx 호출한 직후 종료되는 애플리케이션은 이 플래그를 지정해야 합니다.

백그라운드 스레드에서 실행 작업이 수행되고 호출자가 SEE_MASK_ASYNCOK 플래그를 지정하지 않은 경우 호출 스레드는 반환하기 전에 새 프로세스가 시작될 때까지 기다립니다. 이는 일반적으로 CreateProcess 호출되었거나, DDE 통신이 완료되었거나, 사용자 지정 실행 대리자가 ShellExecuteEx 이를 통보했음을 의미합니다. SEE_MASK_WAITFORINPUTIDLE 플래그가 지정된 경우 ShellExecuteExWaitForInputIdle 호출하고 반환하기 전에 새 프로세스가 유휴 상태가 될 때까지 대기하며 최대 시간 제한은 1분입니다.

이 플래그가 필요한 시기에 대한 자세한 내용은 설명 섹션을 참조하세요.

SEE_MASK_FLAG_DDEWAIT(0x00000100) SEE_MASK_NOASYNC 동일한 옵션을 사용하는 것이 좋습니다.
SEE_MASK_DOENVSUBST(0x00000200) lpDirectory 또는 lpFile 멤버가 지정한 문자열에 지정된 환경 변수를 확장합니다.
SEE_MASK_FLAG_NO_UI(0x00000400) 이 옵션 없이는 일반적으로 표시되는 UI(사용자 인터페이스) 오류 대화 상자를 표시하지 마세요. 보안 프롬프트는 제외되며 계속 표시됩니다.
SEE_MASK_UNICODE(0x00004000) 이 플래그를 사용하여 유니코드 애플리케이션을 나타냅니다.
SEE_MASK_NO_CONSOLE(0x00008000) 새 콘솔을 만드는 대신 새 프로세스에 대한 부모의 콘솔을 상속하는 데 사용합니다. CreateProcessCREATE_NEW_CONSOLE 플래그를 사용하는 것과는 반대입니다.
SEE_MASK_ASYNCOK(0x00100000) 백그라운드 스레드에서 실행을 수행할 수 있으며 백그라운드 스레드가 완료될 때까지 기다리지 않고 호출이 즉시 반환되어야 합니다. 특정 경우에 ShellExecuteEx 이 플래그를 무시하고 반환하기 전에 프로세스가 완료되기를 기다립니다.
SEE_MASK_NOQUERYCLASSSTORE(0x01000000) 사용되지 않습니다.
SEE_MASK_HMONITOR(0x00200000) 다중 모니터 시스템에서 모니터를 지정할 때 이 플래그를 사용합니다. 모니터는 hMonitor 멤버에 지정됩니다. 이 플래그는 SEE_MASK_ICON 함께 사용할 수 없습니다.
SEE_MASK_NOZONECHECKS(0x00800000) 영역 검사를 수행하지 않습니다. 이 플래그를 사용하면 ShellExecuteEx IAttachmentExecute배치된 영역 검사를 무시할 수 있습니다.
SEE_MASK_WAITFORINPUTIDLE(0x02000000) 새 프로세스가 만들어지면 프로세스가 유휴 상태가 될 때까지 기다렸다가 1분 시간 제한으로 반환합니다. 자세한 내용은 WaitForInputIdle 참조하세요.
SEE_MASK_FLAG_LOG_USAGE(0x04000000) 자주 사용하는 프로그램 및 기타 동작을 추적할 수 있는 사용자가 시작한 시작을 나타냅니다.
SEE_MASK_FLAG_HINST_IS_SITE(0x08000000) hInstApp 멤버는 IServiceProvider구현하는 개체의 IUnknown 지정하는 데 사용됩니다. 이 개체는 사이트 포인터로 사용됩니다. 사이트 포인터는 ShellExecute 함수, 처리기 바인딩 프로세스 및 호출된 동사 처리기에 서비스를 제공하는 데 사용됩니다.

ICreatingProcess 제공하여 호출자가 생성되는 프로세스의 일부 매개 변수를 변경할 수 있도록 할 수 있습니다.

이 플래그는 Windows 8 이상에서 지원됩니다.

이 옵션을 지정하면 호출 스레드에서 호출이 동기적으로 실행됩니다.

hwnd

형식: HWND

선택적. 이 함수를 실행하는 동안 시스템에서 생성할 수 있는 UI를 표시하고 배치하는 데 사용되는 소유자 창에 대한 핸들입니다.

lpVerb

형식: LPCTSTR

수행할 작업을 지정하는 동사참조되는 문자열입니다. 사용 가능한 동사 집합은 특정 파일 또는 폴더에 따라 달라집니다. 일반적으로 개체의 바로 가기 메뉴에서 사용할 수 있는 동작은 동사를 사용할 수 있습니다. 이 매개 변수는 NULL수 있습니다. 이 경우 기본 동사가 사용 가능한 경우 사용됩니다. 그렇지 않은 경우 "open" 동사가 사용됩니다. 두 동사를 모두 사용할 수 없는 경우 시스템은 레지스트리에 나열된 첫 번째 동사를 사용합니다. 작업을 특정 동사로 제한할 이유가 없는 경우 계산된 기본값을 사용하도록 NULL을 전달합니다. 예를 들어 SEE_MASK_FLAG_NO_UI 지정하는 경우와 같이 앱이 설치되지 않은 경우 "Open With" UI를 생성하려는 경우가 있습니다.

일반적으로 사용되는 동사는 다음과 같습니다.

  • 편집: 편집기를 시작하고 편집할 문서를 엽니다. lpFile 문서 파일이 아니면 함수가 실패합니다.
  • 탐색: lpFile지정된 폴더를 탐색합니다.
  • 찾기: 지정된 디렉터리부터 검색을 시작합니다.
  • 열린: lpFile 매개 변수로 지정된 파일을 엽니다. 파일은 실행 파일, 문서 파일 또는 폴더일 수 있습니다.
  • openas: 사용자가 lpFile 매개 변수로 지정된 파일을 열 앱을 선택할 수 있도록 선택기 UI를 시작합니다.
  • 인쇄: lpFile지정한 문서 파일을 인쇄합니다. lpFile 문서 파일이 아니면 함수가 실패합니다.
  • 속성: 파일 또는 폴더의 속성을 표시합니다.
  • runas: 관리자 권한으로 애플리케이션을 시작합니다. UAC(사용자 계정 컨트롤)는 관리자 권한으로 애플리케이션을 실행하는 데 동의하라는 메시지를 표시하거나 애플리케이션을 실행하는 데 사용되는 관리자 계정의 자격 증명을 입력합니다.

lpFile

형식: LPCTSTR

ShellExecuteExlpVerb 매개 변수로 지정된 작업을 수행할 파일 또는 개체의 이름을 지정하는 null로 끝나는 문자열의 주소입니다. ShellExecuteEx 함수에서 지원하는 시스템 레지스트리 동사에는 실행 파일 및 문서 파일에 대한 "열기"와 인쇄 처리기가 등록된 문서 파일에 대한 "인쇄"가 포함됩니다. 다른 애플리케이션은 시스템 레지스트리를 통해 셸 동사를 추가했을 수 있습니다(예: .avi 및 .wav 파일에 대한 "재생"). Shell 네임스페이스 개체를 지정하려면 정규화된 구문 분석 이름을 전달하고 fMask 매개 변수에 SEE_MASK_INVOKEIDLIST 플래그를 설정합니다.

참고:SEE_MASK_INVOKEIDLIST 플래그가 설정된 경우 lpFile 또는 lpIDList 사용하여 파일 시스템 경로 또는 해당 PIDL별로 항목을 식별할 수 있습니다. lpFile 또는 lpIDList두 값 중 하나를 설정해야 합니다.
참고: 경로가 이름에 포함되지 않은 경우 현재 디렉터리가 가정됩니다.

lpParameters

형식: LPCTSTR

선택적. 애플리케이션 매개 변수를 포함하는 null로 끝나는 문자열의 주소입니다. 매개 변수는 공백으로 구분해야 합니다. lpFile 멤버가 문서 파일을 지정하는 경우 lpParameters NULL합니다.

lpDirectory

형식: LPCTSTR

선택적. 작업 디렉터리의 이름을 지정하는 null로 끝나는 문자열의 주소입니다. 이 멤버가 NULL경우 현재 디렉터리가 작업 디렉터리로 사용됩니다.

nShow

형식: int

필수. 애플리케이션을 열 때 표시할 방법을 지정하는 플래그입니다. ShellExecute 함수에 대해 나열된 SW_ 값 중 하나입니다. lpFile 문서 파일을 지정하는 경우 플래그는 단순히 연결된 애플리케이션에 전달됩니다. 처리 방법을 결정하는 것은 애플리케이션에 달려 있습니다.

hInstApp

형식: HINSTANCE

[out] SEE_MASK_NOCLOSEPROCESS 설정되고 ShellExecuteEx 호출이 성공하면 이 멤버를 32보다 큰 값으로 설정합니다. 함수가 실패하면 실패의 원인을 나타내는 SE_ERR_XXX 오류 값으로 설정됩니다. hInstApp 16비트 Windows 애플리케이션과의 호환성을 위해 HINSTANCE로 선언되었지만 진정한 HINSTANCE는 아닙니다. int만 캐스팅할 수 있으며 32 또는 다음 SE_ERR_XXX 오류 코드와 비교할 수 있습니다.


오류 코드 이유
SE_ERR_FNF (2) 파일을 찾을 수 없습니다.
SE_ERR_PNF (3) 경로를 찾을 수 없습니다.
SE_ERR_ACCESSDENIED (5) 액세스가 거부되었습니다.
SE_ERR_OOM (8) 메모리 부족.
SE_ERR_DLLNOTFOUND (32) 동적 링크 라이브러리를 찾을 수 없습니다.
SE_ERR_SHARE (26) 열려 있는 파일을 공유할 수 없습니다.
SE_ERR_ASSOCINCOMPLETE (27) 파일 연결 정보가 완료되지 않았습니다.
SE_ERR_DDETIMEOUT (28) DDE 작업 시간이 초과되었습니다.
SE_ERR_DDEFAIL (29) DDE 작업이 실패했습니다.
SE_ERR_DDEBUSY (30) DDE 작업이 사용 중입니다.
SE_ERR_NOASSOC (31) 파일 연결을 사용할 수 없습니다.

lpIDList

형식: LPVOID

실행할 파일을 고유하게 식별하는 항목 식별자 목록을 포함하는 절대 ITEMIDLIST 구조체(PCIDLIST_ABSOLUTE)의 주소입니다. 이 멤버는 fMask 멤버에 SEE_MASK_IDLIST 또는 SEE_MASK_INVOKEIDLIST포함하지 않는 경우 무시됩니다.

lpClass

형식: LPCTSTR

다음 중 하나를 지정하는 null로 끝나는 문자열의 주소입니다.

  • ProgId입니다. 예를 들어 "Paint.Picture"입니다.
  • URI 프로토콜 체계입니다. 예를 들어 "http"입니다.
  • 파일 확장명입니다. 예를 들어 ".txt"입니다.
  • 하나 이상의 Shell 동사가 포함된 하위 키의 이름을 지정하는 HKEY_CLASSES_ROOT 아래의 레지스트리 경로입니다. 이 키에는 \동사 이름같은 셸 동사 레지스트리 스키마를 준수하는 하위 키가 있습니다.

fMaskSEE_MASK_CLASSNAME포함하지 않으면 이 멤버는 무시됩니다.

hkeyClass

형식: HKEY

파일 형식에 대한 레지스트리 키에 대한 핸들입니다. 이 레지스트리 키에 대한 액세스 권한은 KEY_READ 설정해야 합니다. fMaskSEE_MASK_CLASSKEY포함하지 않으면 이 멤버는 무시됩니다.

dwHotKey

형식: DWORD

애플리케이션과 연결할 바로 가기 키입니다. 하위 단어는 가상 키 코드이며, 상위 단어는 한정자 플래그(HOTKEYF_)입니다. 한정자 플래그 목록은 WM_SETHOTKEY 메시지에 대한 설명을 참조하세요. fMaskSEE_MASK_HOTKEY포함하지 않으면 이 멤버는 무시됩니다.

DUMMYUNIONNAME

DUMMYUNIONNAME.hIcon

형식: HANDLE

파일 형식의 아이콘에 대한 핸들입니다. fMaskSEE_MASK_ICON포함하지 않으면 이 멤버는 무시됩니다. 이 값은 Windows XP 및 이전 버전에서만 사용됩니다. Windows Vista에서 무시됩니다.

DUMMYUNIONNAME.hMonitor

형식: HANDLE

문서를 표시할 모니터에 대한 핸들입니다. fMaskSEE_MASK_HMONITOR포함하지 않으면 이 멤버는 무시됩니다.

hProcess

형식: HANDLE

새로 시작된 애플리케이션에 대한 핸들입니다. 이 멤버는 반환 시 설정되며 fMask SEE_MASK_NOCLOSEPROCESS설정되지 않는 한 항상 NULL . fMask SEE_MASK_NOCLOSEPROCESS설정하더라도 프로세스가 시작되지 않은 경우 hProcess NULL . 예를 들어 시작할 문서가 URL이고 Internet Explorer 인스턴스가 이미 실행 중인 경우 문서가 표시됩니다. 새 프로세스가 시작되지 않으며 hProcess NULL.

참고:ShellExecuteEx 호출의 결과로 프로세스가 시작되더라도 항상 hProcess반환하지는 않습니다. 예를 들어 hProcessSEE_MASK_INVOKEIDLIST 사용하여 IContextMenu호출할 때 반환되지 않습니다.

발언

SEE_MASK_NOASYNC 플래그는 ShellExecuteEx 호출하는 스레드에 메시지 루프가 없거나 ShellExecuteEx가 반환된 직후 스레드 또는 프로세스가 종료되는 경우 지정해야. 이러한 조건에서는 DDE 대화를 완료하는 데 호출 스레드를 사용할 수 없으므로 호출 애플리케이션으로 제어를 반환하기 전에 ShellExecuteEx 대화를 완료해야 합니다. 대화를 완료하지 못하면 문서가 시작되지 않을 수 있습니다.

호출 스레드에 메시지 루프가 있고 ShellExecuteEx 호출이 반환된 후 일정 시간 동안 존재하는 경우 SEE_MASK_NOASYNC 플래그는 선택 사항입니다. 플래그를 생략하면 호출 스레드의 메시지 펌프가 DDE 대화를 완료하는 데 사용됩니다. DDE 대화가 백그라운드에서 완료될 수 있으므로 호출 애플리케이션은 더 빨리 제어권을 되찾습니다.

lpParameters큰따옴표를 포함하려면 다음 예제와 같이 각 표시를 따옴표 쌍으로 묶습니다.

sei.lpParameters = "An example: \"\"\"quoted text\"\"\"";

이 경우 애플리케이션은 세 가지 매개 변수를 받습니다. , 예제:및 "따옴표 붙은 텍스트".

메모

shellapi.h 헤더는 UNICODE 전처리기 상수의 정의에 따라 이 함수의 ANSI 또는 유니코드 버전을 자동으로 선택하는 별칭으로 SHELLEXECUTEINFO를 정의합니다. 인코딩 중립 별칭을 인코딩 중립이 아닌 코드와 혼합하면 컴파일 또는 런타임 오류가 발생하는 불일치가 발생할 수 있습니다. 자세한 내용은 함수 프로토타입대한 규칙을 참조하세요.

요구 사항

요구
지원되는 최소 클라이언트 Windows XP [데스크톱 앱만 해당]
지원되는 최소 서버 Windows 2000 Server [데스크톱 앱만 해당]
헤더 shellapi.h