ObjectContext::CreateInstance 메서드(comsvcs.h)
현재 개체의 컨텍스트를 사용하여 개체를 만듭니다.
해당 구성 요소가 COM+에 등록된 경우에만 개체에 컨텍스트가 있습니다.
구문
HRESULT CreateInstance(
[in] BSTR bstrProgID,
[out] VARIANT *pObject
);
매개 변수
[in] bstrProgID
인스턴스화할 개체 형식의 ProgID입니다.
[out] pObject
새 개체에 대한 참조입니다.
반환 값
이 메서드는 다음 값뿐만 아니라 E_INVALIDARG, E_OUTOFMEMORY 및 E_FAIL 표준 반환 값을 반환할 수 있습니다.
반환 코드 | Description |
---|---|
|
메서드가 완료되었습니다. |
|
예기치 않은 오류가 발생했습니다. 이 문제는 한 개체가 ObjectContext 포인터를 다른 개체에 전달하고 다른 개체가 이 포인터를 사용하여 CreateInstance 를 호출하는 경우에 발생할 수 있습니다. ObjectContext 포인터는 원래 가져온 개체의 컨텍스트 외부에서 유효하지 않습니다. |
설명
CreateInstance를 사용하여 개체를 만들 때 새 개체의 컨텍스트는 현재 개체의 ObjectContext 및 새 개체 구성 요소의 선언적 속성에서 파생됩니다. 새 개체는 항상 개체를 만든 개체와 동일한 작업 내에서 실행됩니다. 현재 개체에 트랜잭션이 있는 경우 새 개체 구성 요소의 트랜잭션 특성은 새 개체가 해당 트랜잭션의 scope 내에서 실행되는지 여부를 결정합니다.
구성 요소의 트랜잭션 특성 설정에 트랜잭션이 필요하거나 트랜잭션을 지원하는 경우 새 개체는 작성자의 트랜잭션을 상속합니다. 구성 요소의 트랜잭션 특성에 새 트랜잭션이 필요한 경우 COM+는 새 개체에 대한 새 트랜잭션을 시작합니다. 구성 요소의 트랜잭션 특성이 트랜잭션을 지원하지 않는 경우 새 개체는 트랜잭션에서 실행되지 않습니다.
요구 사항
요구 사항 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows 2000 Professional[데스크톱 앱만] |
지원되는 최소 서버 | Windows 2000 Server[데스크톱 앱만] |
대상 플랫폼 | Windows |
헤더 | comsvcs.h |