반응형

PIA .NET 프레임워크가 처음 도입된 2000년대 초반 이후부터 존재해 온 기술 입니다. 이 글을 통해 PIA에 대한 기본 개념을 익히고, 예제 소스를 통해 실제로 어떻게 사용되는지 알아보겠습니다.

1.   Primary Interop Assembly(PIA)?

Primary Interop Assembly(PIA)는 마이크로소프트에서 제공하는 기술로, .NET 어플리케이션에서 COM 기반의 컴포넌트를 사용할 수 있게 도와주는 역할을 합니다. 여기서 COM(Component Object Model)은 마이크로소프트에서 개발한 프로그래밍 인터페이스로, 개발자들이 객체 지향 프로그래밍을 통해 모듈화된 소프트웨어를 개발할 수 있도록 도와줍니다.

간단히 말해, PIA .NET 환경에서 COM 기반의 컴포넌트를 사용할 수 있게 해주는 "다리" 역할을 하는 것입니다.

2.   PIA가 필요한가?

그렇다면 왜 PIA가 필요할까요? 이는 .NET COM 기반 컴포넌트 간에 런타임 환경의 차이 때문입니다. .NET은 고유의 런타임 환경인 CLR(Common Language Runtime)을 사용하며, COM 기반 컴포넌트는 Win32 기반의 네이티브 런타임 환경을 가지고 있습니다. 이러한 차이로 인해 두 시스템 간에 직접적인 통신이 어렵습니다. 따라서 PIA를 사용하여 .NET COM 간의 통신을 원활하게 만들어주는 것이 필요한 것입니다.

3.   PIA 작동 원리

앞서 말한 바와 같이 PIA .NET 어플리케이션에서 COM 기반 컴포넌트를 사용할 수 있게 해주는 "다리" 역할을 합니다. 이는 COM Callable Wrapper (CCW) Runtime Callable Wrapper (RCW) 두 가지 방식으로 이루어집니다.

  • COM Callable Wrapper (CCW): .NET에서 개발된 객체를 COM 기반 컴포넌트가 호출할 수 있도록 해주는 기능입니다.
  • Runtime Callable Wrapper (RCW): COM 기반 컴포넌트를 .NET 어플리케이션에서 호출할 수 있도록 해주는 기능입니다.

4.   PIA 생성 및 참조

PIA는 특별한 형태의 어셈블리로, COM 컴포넌트의 메타데이터를 포함하며 이를 .NET 환경에서 사용할 수 있도록 해줍니다. PIA를 생성하려면 먼저 COM 컴포넌트의 타입 라이브러리(Type Library) .NET 어셈블리로 변환해야 합니다. 이를 위해 마이크로소프트에서 제공하는 Type Library Importer(tlbimp.exe) 도구를 사용할 수 있습니다.

예를 들어, COM 컴포넌트인 Microsoft Excel PIA를 생성하려면 다음 명령을 실행합니다. 

tlbimp.exe "C:\Path\To\Excel.tlb" /out:"C:\Path\To\Output\Microsoft.Office.Interop.Excel.dll"

명령을 실행한 후, 생성된 PIA .NET 프로젝트에 참조해야 합니다. Visual Studio에서 참조를 추가하는 방법은 다음과 같습니다.

  1. 프로젝트를 마우스 오른쪽 버튼으로 클릭한 후, '참조 추가'를 선택합니다.
  2. '찾아보기' 탭을 클릭한 후, 생성된 PIA dll 파일을 찾아 선택합니다.
  3. '확인'을 클릭하여 참조를 추가합니다.

경우에 따라 COM 컴포넌트 제작 업체에서 해당 제품에 대한 공식 PIA를 제공할 수 있습니다. 이러한 PIA는 COM 컴포넌트와의 통합이 잘 이루어지도록 최적화되어 있을 수 있으며, 업체에서 지원되는 방식으로 사용하는 것이 좋습니다.

또한 Visual Studio에서는 "참조 추가" 대화상자를 통해 COM 컴포넌트를 선택함으로써, 자동으로 해당 COM 컴포넌트(구성요소)에 대한 런타임 호출 가능 래퍼(Runtime Callable Wrapper, RCW)가 생성됩니다. 이 RCW는 PIA와 비슷한 역할을 수행합니다.

Visual Studio에서 COM 컴포넌트를 참조하려면 다음과 같이 합니다.

  1. 프로젝트를 마우스 오른쪽 버튼으로 클릭한 후, '참조 추가'를 선택합니다.
  2. 'COM' 탭을 클릭한 후, 원하는 COM 컴포넌트를 선택합니다.
  3. '확인'을 클릭하여 참조를 추가합니다.

이렇게 하면, COM 컴포넌트를 사용할 수 있는 인터페이스가 포함된 interop 어셈블리가 자동으로 생성되고 프로젝트에 추가됩니다. 이 interop 어셈블리는 PIA와 유사한 기능을 수행하며, 프로젝트에서 COM 컴포넌트의 기능을 사용할 수 있게 합니다.

5.   예제 소스

아래 예제에서는 .NET에서 COM 기반 컴포넌트를 사용하는 방법을 살펴보겠습니다. 이 예제에서는 마이크로소프트 엑셀(Microsoft Excel) COM 기반 컴포넌트로 사용합니다.

using System;
using Excel = Microsoft.Office.Interop.Excel;

namespace ExcelInteropExample
{
    class Program
    {
        static void Main(string[] args)
        {
            // 엑셀 애플리케이션 객체 생성 (PIA를 사용하여 COM 컴포넌트를 호출)
            Excel.Application excelApp = new Excel.Application();
            // 엑셀 파일을 새로 생성하거나 기존 파일을 열기
            Excel.Workbook workbook = excelApp.Workbooks.Add();
            Excel.Worksheet worksheet = workbook.ActiveSheet;

            // 셀에 데이터 입력
            worksheet.Cells[1, 1] = "Hello";
            worksheet.Cells[1, 2] = "World";

            // 엑셀 파일 저장
            workbook.SaveAs("C:\\Path\\To\\Output\\Sample.xlsx");

            // 엑셀 애플리케이션 및 워크북 종료
            workbook.Close();
            excelApp.Quit();

            // COM 객체 메모리 해제
            System.Runtime.InteropServices.Marshal.ReleaseComObject(worksheet);
            System.Runtime.InteropServices.Marshal.ReleaseComObject(workbook);
            System.Runtime.InteropServices.Marshal.ReleaseComObject(excelApp);

            Console.WriteLine("Excel file created successfully!");
        }
    }
}

PIA와 관련된 기술들은 지속적으로 발전하고 있으며, 이에 따라 개발자들이 상호 운용성을 확보하는 데 필요한 노력이 점점 줄어들고 있습니다. 예를 들어, .NET Core와 .NET 5에서는 COM 호스트를 통해 PIA 없이도 COM 기반 컴포넌트를 사용할 수 있게 되었습니다. 이러한 발전을 통해 앞으로 상호 운용성이 더욱 간편하고 효율적으로 구현될 것으로 예상됩니다.

 

반응형

'개발정보' 카테고리의 다른 글

[NSIS] .Net Framework 설치 포함  (0) 2023.07.07
COM 개체와 타입 라이브러리(Type Library)  (0) 2023.03.21
RCW(Runtime Callable Wrapper)란  (0) 2023.03.21
COM 구성 요소란  (0) 2023.03.20
[.net] interop 과 p/invoke  (0) 2023.03.20
반응형

COM(Components Object Model, COM)은 마이크로소프트에서 개발한 소프트웨어 컴포넌트 기술로, 다른 소프트웨어에서 사용할 수 있는 기능을 제공하는 객체지향 프로그래밍 모델입니다. COM 개체는 이식성이 좋고, 다른 프로그램과 상호작용할 수 있는 인터페이스를 제공합니다. 일반적으로 COM 개체는 DLL(Dynamic-Link Library) 파일 혹은 EXE(Executable) 파일에 구현될 수 있습니다. 

타입 라이브러리(Type Library)는 COM 개체가 제공하는 인터페이스와 메서드, 프로퍼티 등의 정보를 포함하는 라이브러리입니다. 이 정보를 바탕으로 개발자들은 다른 프로그램에서 COM 개체를 사용할 때 필요한 코드를 작성할 수 있습니다. 타입 라이브러리는 주로 TLB 확장자를 갖는 별도의 파일에 저장됩니다.

COM 개체와 타입 라이브러리는 서로 밀접한 관계를 갖습니다. COM 개체를 만들 때에는 해당 개체가 제공하는 인터페이스와 메서드 등을 타입 라이브러리에 정의하고 등록해야 합니다. 그리고 다른 프로그램에서 COM 개체를 사용할 때에는 해당 개체의 타입 라이브러리를 참조하여 개체의 인터페이스와 메서드를 호출합니다.

따라서 COM 개체와 타입 라이브러리는 서로 보완적인 역할을 수행합니다. COM 개체는 기능을 제공하고, 타입 라이브러리는 해당 개체의 인터페이스와 메서드 등을 정의하여 개발자들이 COM 개체를 사용할 수 있도록 도와줍니다.

비유하자면 타입 라이브러리는 COM 개체에 대한 메뉴판이라고 할 수 있습니다. 메뉴판을 보면 어떤 음식이 있는지, 그 음식이 어떻게 만들어졌는지, 어떤 재료로 만들어졌는지 등에 대한 정보를 얻을 수 있습니다. 마찬가지로 타입 라이브러리를 보면 COM개체에 어떤 인터페이스와 메서드가 있는지, 그 인터페이스와 메서드, 프로퍼티 등을 어떻게 사용해야 하는지, 어떤 인자를 전달해야 하는지 등에 대한 정보를 얻을 수 있습니다.

따라서 개발자들은 타입 라이브러리를 참조하여 COM 개체의 인터페이스와 메서드 등에 대한 정보를 얻고, 이를 바탕으로 COM 개체를 사용하는 코드를 작성할 수 있습니다.

반응형

'개발정보' 카테고리의 다른 글

[NSIS] .Net Framework 설치 포함  (0) 2023.07.07
PIA(Primary Interop Assembly) 란?  (0) 2023.03.21
RCW(Runtime Callable Wrapper)란  (0) 2023.03.21
COM 구성 요소란  (0) 2023.03.20
[.net] interop 과 p/invoke  (0) 2023.03.20
반응형

런타임 Callable Wrapper(RCW)는 COM(Component Object Model) 기술을 사용하여 .NET 언어와 같은 매니지드 언어에서 COM 개체를 호출할 때 사용되는 개체입니다.

COM 개체는 C++과 같은 비매니지드 언어로 작성되며, 매니지드 언어에서 직접 호출할 수 없습니다. 따라서 RCW는 COM 개체와 매니지드 언어 간의 인터페이스 역할을 합니다. RCW는 COM 개체에 대한 참조를 포함하며, 해당 개체를 호출하기 위해 필요한 래퍼 코드를 생성합니다.

RCW는 .NET에서 COM 개체를 사용할 때 중요한 역할을 합니다. RCW를 사용하면 매니지드 코드에서 COM 개체를 사용하기 쉬워지며, COM 개체와 .NET 런타임 간의 상호 운용성을 개선할 수 있습니다. 또한 RCW는 .NET 언어에서 COM 개체를 사용하기 위해 필요한 다양한 기능, 예를 들어 자동 메모리 관리 및 예외 처리와 같은 기능을 제공합니다.

RCW는 .NET Framework에서 제공하는 기능 중 하나이며, 개발자가 직접 만들 필요가 없습니다. RCW는 .NET에서 COM 개체를 사용하기 위해 필요한 인터페이스를 런타임에 해당 개체에 대한 인스턴스를 생성할 때마다 동적으로 자동으로 생성합니다. 

RCW가 동적으로 생성되는 이유는 COM 개체가 .NET Framework의 메모리 관리와 스레딩 모델과 다르게 동작하기 때문입니다. RCW는 .NET Framework에서 COM 개체를 호출하기 위해 필요한 래퍼 코드를 생성하며, 이를 통해 .NET Framework와 COM 개체 간의 상호 작용을 보다 효율적으로 처리할 수 있습니다.

RCW는 가비지 컬렉션 처리도 담당합니다. 해당 COM 개체가 더 이상 필요하지 않은 경우, RCW는 개체에 대한 참조를 해제하고 메모리를 해제합니다.

반응형

'개발정보' 카테고리의 다른 글

PIA(Primary Interop Assembly) 란?  (0) 2023.03.21
COM 개체와 타입 라이브러리(Type Library)  (0) 2023.03.21
COM 구성 요소란  (0) 2023.03.20
[.net] interop 과 p/invoke  (0) 2023.03.20
[C#] params 키워드  (0) 2023.02.15
반응형

Interop(Interoperability)는 서로 다른 프로그래밍 언어, 플랫폼, 기술 등 간의 상호 운용성을 지원하는 기술입니다. 특히, .NET 언어에서 Interop은 다른 플랫폼이나 라이브러리 등을 사용할 수 있도록 하는 방법을 제공합니다.

Interop은 COM(Component Object Model)과 관련된 기술로 시작되었습니다. COM은 Microsoft에서 개발한 프로그래밍 모델로, 다른 프로그래밍 언어나 플랫폼에서 COM 구성 요소를 사용할 수 있도록 하는 Interop 기술을 제공합니다. 이후 .NET Framework가 등장하면서 Interop 기술은 COM 뿐만 아니라 다른 플랫폼, 기술과도 상호 운용성을 지원하게 되었습니다.

Interop은 Windows 운영 체제에서 사용되는 외부 binary와 상호 작용할 수 있도록 해주는 기술입니다. Interop은 COM Interop, P/Invoke 및 C++ Interop을 포함한 .NET Framework의 다양한 상호 운용 기술을 일컫는 말입니다. 따라서 P/Invoke는 Interop 기술 중 하나입니다.

P/Invoke와 COM Interop은 각각 다른 방식으로 Interop을 지원합니다. P/Invoke는 C/C++ 함수를 선언하고, 해당 함수를 호출하는 방식으로 상호 운용성을 지원합니다. COM Interop은 COM 구성 요소를 .NET 언어에서 사용할 수 있는 클래스로 래핑하여 상호 운용성을 지원합니다.

COM Interop의 주요 용도로서 Microsoft Office 제품군과의 상호 운용성이 있습니다. C#과 같은 .NET Framework 언어로 작성된 애플리케이션에서 Microsoft Word 문서를 조작하려면, COM Interop을 사용하여 Word의 COM 객체 모델에 액세스해야 합니다.

COM Interop을 사용하여 Word와의 상호 운용성을 지원하는 코드 예제는 다음과 같습니다.

using Word = Microsoft.Office.Interop.Word;

// Word Application 인스턴스 생성
Word.Application wordApp = new Word.Application();

// Word Document 인스턴스 생성
Word.Document wordDoc = wordApp.Documents.Add();

// Document 내용 수정
Word.Paragraph para1 = wordDoc.Content.Paragraphs.Add();
para1.Range.Text = "Hello, World!";

// Document 저장
wordDoc.SaveAs2("C:\\Temp\\Hello.docx");

// Word 종료
wordDoc.Close();
wordApp.Quit();


P/Invoke는 Platform Invocation Services의 약자로, .NET Framework에서 C# 또는 다른 .NET 언어로 C/C++ 외부 DLL 함수를 호출하는 방법을 제공합니다. 즉 P/Invoke를 사용하여 Win32 API를 포함한 C/C++ DLL 함수를 호출할 수 있으며, 이를 통해 .NET으로 개발되지 않은 기존의 많은 DLL의 기능을 활용할 수 있습니다.

P/Invoke는 외부 DLL 함수를 호출하기 위해 일반적으로 DllImport 어트리뷰트를 사용합니다. DllImport 어트리뷰트는 해당 DLL 파일과 함수의 이름을 지정하고, 필요한 경우 함수 매개변수 및 반환 값에 대한 정보를 제공합니다.

예를 들어, C#에서 Win32 API 함수 중 MessageBox 함수를 호출하려면 다음과 같이 DllImport 어트리뷰트를 사용하여 함수 이름을 지정하고, 필요한 경우 함수 매개변수 및 반환 값에 대한 정보를 제공해야 합니다.

[DllImport("user32.dll", CharSet = CharSet.Auto)]
public static extern MessageBoxResult MessageBox(IntPtr hWnd, string text, string caption, uint type);

P/Invoke를 사용할 때는 또한 해당 함수의 호출 규약(calling convention)과 매개변수의 전달 방식 등을 고려해야 합니다. 대부분의 DLL 함수는 C 언어 기반으로 작성되므로, C calling convention을 사용하며, 일부 함수는 STDCALL calling convention을 사용합니다.

P/Invoke를 사용하여 C/C++ DLL 함수를 호출할 때는 함수 매개변수 및 반환 값의 자료형이 호환되어야 합니다. 예를 들어, C#에서 int 자료형은 C/C++에서 int 자료형과 호환되지만, string 자료형은 C/C++에서 wchar_t 배열과 호환되므로 이에 대한 변환 작업이 필요합니다.

이 때 호출하는 함수와 .NET 언어 간에 데이터 형식이 다른 경우에는 마샬링(marshaling) 기술이 사용됩니다.

마샬링은 서로 다른 프로그래밍 언어나 환경에서 데이터를 주고받을 때 데이터의 형식을 변환하는 과정입니다. P/Invoke에서도 호출하는 함수와 .NET 언어 간에 데이터 형식이 다른 경우에는 이를 변환하는 마샬링 기술이 사용됩니다. P/Invoke에서는 이러한 마샬링 과정을 자동으로 처리해주는 기능을 제공하며, 일부 자료형의 경우에는 사용자가 직접 변환 과정을 처리해주어야 합니다.

참고로 P/Invoke를 위한 Win32 API의 메소드 원형을 쉽게 작성하기 위해서는 pinvoke.net 사이트를 이용하면 편리 합니다.

반응형

'개발정보' 카테고리의 다른 글

RCW(Runtime Callable Wrapper)란  (0) 2023.03.21
COM 구성 요소란  (0) 2023.03.20
[C#] params 키워드  (0) 2023.02.15
[C#] Initializer(이니셜라이저)의 종류와 사용법  (0) 2023.02.13
[C#] 객체 초기화  (0) 2023.02.13

+ Recent posts