RegOpenKeyTransactedA 함수(winreg.h)

지정된 레지스트리 키를 열고 트랜잭션과 연결합니다. 키 이름은 대/소문자를 구분하지 않습니다.

구문

LSTATUS RegOpenKeyTransactedA(
  [in]           HKEY   hKey,
  [in, optional] LPCSTR lpSubKey,
  [in]           DWORD  ulOptions,
  [in]           REGSAM samDesired,
  [out]          PHKEY  phkResult,
  [in]           HANDLE hTransaction,
                 PVOID  pExtendedParemeter
);

매개 변수

[in] hKey

열린 레지스트리 키에 대한 핸들입니다. 이 핸들은 RegCreateKeyEx, RegCreateKeyTransacted, RegOpenKeyEx 또는 RegOpenKeyTransacted 함수에서 반환됩니다. 다음 미리 정의된 키 중 하나일 수도 있습니다.

HKEY_CLASSES_ROOTHKEY_CURRENT_USERHKEY_LOCAL_MACHINEHKEY_USERS

[in, optional] lpSubKey

열 레지스트리 하위 키의 이름입니다.

키 이름은 대/소문자를 구분하지 않습니다.

lpSubKey 매개 변수가 NULL 또는 빈 문자열에 대한 포인터이고 hKey가 미리 정의된 키인 경우 시스템은 미리 정의된 키를 새로 고치고 phkResult는 함수에 전달된 동일한 hKey 핸들을 받습니다. 그렇지 않으면 phkResult 는 열린 키에 대한 새 핸들을 받습니다.

자세한 내용은 레지스트리 요소 크기 제한을 참조하세요.

[in] ulOptions

이 매개 변수는 예약되어 있으며 0이어야 합니다.

[in] samDesired

키에 대한 원하는 액세스 권한을 지정하는 마스크입니다. 키의 보안 설명자가 호출 프로세스에 대해 요청된 액세스를 허용하지 않으면 함수가 실패합니다. 자세한 내용은 레지스트리 키 보안 및 액세스 권한을 참조하세요.

[out] phkResult

열린 키에 대한 핸들을 수신하는 변수에 대한 포인터입니다. 키가 미리 정의된 레지스트리 키 중 하나가 아닌 경우 핸들 사용을 마친 후 RegCloseKey 함수를 호출합니다.

[in] hTransaction

활성 트랜잭션에 대한 핸들입니다. 이 핸들은 CreateTransaction 함수에서 반환됩니다.

pExtendedParemeter

이 매개 변수는 예약되어 있으며 NULL이어야 합니다.

반환 값

함수가 성공하면 반환 값이 ERROR_SUCCESS.

함수가 실패하면 반환 값은 Winerror.h에 정의된 0이 아닌 오류 코드입니다. FormatMessage 함수를 FORMAT_MESSAGE_FROM_SYSTEM 플래그와 함께 사용하여 오류에 대한 일반적인 설명을 가져올 수 있습니다.

설명

이 함수를 사용하여 키를 열면 키에 대한 후속 작업이 트랜잭션됩니다. 트랜잭션이 커밋되기 전에 키에 대해 트랜잭션되지 않은 작업이 수행되면 트랜잭션이 롤백됩니다. 트랜잭션이 커밋되거나 롤백된 후에는 활성 트랜잭션 핸들이 있는 RegCreateKeyTransacted 또는 RegOpenKeyTransacted 함수를 사용하여 키를 다시 열어 추가 작업을 트랜잭션해야 합니다. 트랜잭션에 대한 자세한 내용은 커널 트랜잭션 관리자를 참조하세요.

이 키의 하위 키에 대한 후속 작업은 자동으로 트랜잭션되지 않습니다. 따라서 RegDeleteKeyEx 함수는 트랜잭션된 삭제 작업을 수행하지 않습니다. 대신 RegDeleteKeyTransacted 함수를 사용하여 트랜잭션된 삭제 작업을 수행합니다.

RegCreateKeyTransacted 함수와 달리 레지스트리에 키가 없는 경우 RegOpenKeyTransacted 함수는 지정된 키를 만들지 않습니다.

서비스 또는 애플리케이션이 다른 사용자를 가장하는 경우 HKEY_CURRENT_USER 이 함수를 사용하지 마세요. 대신 RegOpenCurrentUser 함수를 호출합니다.

phkResult에서 반환된 키가 미리 정의된 레지스트리 키인 경우 제공된 트랜잭션에 포함되지 않습니다.

단일 레지스트리 키는 65,534번만 열 수 있습니다. 65,535번째 열린 작업을 시도할 때 이 함수는 ERROR_NO_SYSTEM_RESOURCES 함께 실패합니다.

참고

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

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows Vista [데스크톱 앱만 해당]
지원되는 최소 서버 Windows Server 2008 [데스크톱 앱만 해당]
대상 플랫폼 Windows
헤더 winreg.h(Windows.h 포함)
라이브러리 Advapi32.lib
DLL Advapi32.dll

추가 정보

RegCloseKey

RegCreateKeyTransacted

RegDeleteKeyTransacted

레지스트리 함수

레지스트리 개요