연습: 동적 연결 라이브러리 만들기 및 사용(C++)
처음 만들 라이브러리 형식은 DLL(동적 연결 라이브러리)입니다. DLL을 사용하면 코드를 매우 편리하게 다시 사용할 수 있습니다. 프로그램을 만들 때마다 동일한 루틴을 다시 구현하는 대신 해당 루틴을 한 번만 작성한 다음 이 기능이 필요한 응용 프로그램에서 루틴을 참조하도록 합니다.
이 연습에서는 다음과 같은 내용을 다룹니다.
새 DLL(동적 연결 라이브러리) 프로젝트 만들기
동적 연결 라이브러리에 클래스 추가
동적 연결 라이브러리를 참조하는 응용 프로그램 만들기
콘솔 응용 프로그램에서 클래스 라이브러리의 기능 사용
응용 프로그램 실행
사전 요구 사항
이 항목에서는 사용자가 C++ 언어의 기본적인 사항을 알고 있는 것으로 가정합니다. 이제 C++를 배우기 시작하는 초보자는 Herb Schildt가 쓴 "C++ Beginner's Guide"(https://go.microsoft.com/fwlink/?LinkId=115303)를 참조하는 것이 좋습니다.
새 DLL(동적 연결 라이브러리) 프로젝트를 만들려면
파일 메뉴에서 새로 만들기를 선택한 다음 **프로젝트...**를 선택합니다.
프로젝트 형식 창의 **Visual C++**에서 Win32를 선택합니다.
템플릿 창에서 Win32 콘솔 응용 프로그램을 선택합니다.
프로젝트의 이름(예: MathFuncsDll)을 선택하고 이름 필드에 입력합니다. 솔루션의 이름(예: DynamicLibrary)을 선택하고 솔루션 이름 필드에 입력합니다.
확인을 클릭하여 Win32 응용 프로그램 마법사를 시작합니다. Win32 응용 프로그램 마법사 대화 상자의 개요 페이지에서 다음을 클릭합니다.
Win32 응용 프로그램 마법사의 응용 프로그램 설정 페이지에 있는 응용 프로그램 종류에서 DLL을 선택할 수 있으면 이를 선택하고 DLL을 선택할 수 없으면 콘솔 응용 프로그램을 선택합니다. 일부 버전의 Visual Studio에서는 마법사를 사용하여 DLL 프로젝트를 만들 수 없습니다. 나중에 이를 변경하여 프로젝트를 DLL로 컴파일할 수 있습니다.
Win32 응용 프로그램 마법사의 응용 프로그램 설정 페이지에 있는 추가 옵션에서 빈 프로젝트를 선택합니다.
마침을 클릭하여 프로젝트를 만듭니다.
동적 연결 라이브러리에 클래스를 추가하려면
새 클래스의 헤더 파일을 만들려면 프로젝트 메뉴에서 **새 항목 추가...**를 선택합니다. 새 항목 추가 대화 상자가 표시됩니다. 범주 창의 **Visual C++**에서 코드를 선택합니다. 템플릿 창에서 **헤더 파일 (.h)**을 선택합니다. 헤더 파일의 이름(예: MathFuncsDll.h)을 선택하고 추가를 클릭합니다. 빈 파일이 표시됩니다.
덧셈, 뺄셈, 곱셈, 나눗셈 같은 일반적인 산술 연산을 수행하는 MyMathFuncs라는 간단한 클래스를 추가합니다. 코드는 다음과 같습니다.
// MathFuncsDll.h namespace MathFuncs { class MyMathFuncs { public: // Returns a + b static __declspec(dllexport) double Add(double a, double b); // Returns a - b static __declspec(dllexport) double Subtract(double a, double b); // Returns a * b static __declspec(dllexport) double Multiply(double a, double b); // Returns a / b // Throws DivideByZeroException if b is 0 static __declspec(dllexport) double Divide(double a, double b); }; }
이 코드의 메서드 선언에서 __declspec(dllexport) 한정자에 주목할 필요가 있습니다. 이러한 한정자를 사용하면 DLL에서 메서드를 내보내 다른 응용 프로그램에서 해당 메서드를 사용하도록 할 수 있습니다. 자세한 내용은 dllexport, dllimport를 참조하십시오.
새 클래스의 소스 파일을 만들려면 프로젝트 메뉴에서 **새 항목 추가...**를 선택합니다. 새 항목 추가 대화 상자가 표시됩니다. 범주 창의 **Visual C++**에서 코드를 선택합니다. 템플릿 창에서 **C++ 파일 (.cpp)**을 선택합니다. 소스 파일의 이름(예: MathFuncsDll.cpp)을 선택하고 추가를 클릭합니다. 빈 파일이 표시됩니다.
소스 파일에서 MyMathFuncs의 기능을 구현합니다. 코드는 다음과 같습니다.
// MathFuncsDll.cpp // compile with: /EHsc /LD #include "MathFuncsDll.h" #include <stdexcept> using namespace std; namespace MathFuncs { double MyMathFuncs::Add(double a, double b) { return a + b; } double MyMathFuncs::Subtract(double a, double b) { return a - b; } double MyMathFuncs::Multiply(double a, double b) { return a * b; } double MyMathFuncs::Divide(double a, double b) { if (b == 0) { throw new invalid_argument("b cannot be zero!"); } return a / b; } }
프로젝트를 DLL로 빌드하려면 프로젝트 메뉴에서 MathFuncsDll **속성...**을 선택합니다. 왼쪽 창의 구성 속성에서 일반을 선택합니다. 오른쪽 창에서 구성 형식을 **동적 라이브러리 (.dll)**로 변경합니다. 확인을 클릭하여 변경 내용을 저장합니다.
참고
명령줄에서 프로젝트를 빌드하고 있는 경우 /LD 컴파일러 옵션을 사용하여 출력 파일이 DLL이 되도록 지정합니다. 자세한 내용은 /MD, /MT, /LD(런타임 라이브러리 사용)를 참조하십시오.
빌드 메뉴에서 솔루션 빌드를 선택하여 동적 연결 라이브러리를 컴파일합니다. 이렇게 하면 다른 프로그램에서 사용할 수 있는 DLL이 작성됩니다. DLL에 대한 자세한 내용은 DLL을 참조하십시오.
동적 연결 라이브러리를 참조하는 응용 프로그램을 만들려면
방금 만든 동적 연결 라이브러리를 참조하고 사용하는 응용 프로그램을 만들려면 파일 메뉴에서 새로 만들기를 선택한 다음 **프로젝트...**를 선택합니다.
프로젝트 형식 창의 **Visual C++**에서 Win32를 선택합니다.
템플릿 창에서 Win32 콘솔 응용 프로그램을 선택합니다.
프로젝트의 이름(예: MyExecRefsDll)을 선택하고 이름 필드에 입력합니다. 솔루션 옆에 있는 드롭다운 목록에서 솔루션에 추가를 선택합니다. 이렇게 하면 새 프로젝트가 동일한 솔루션에 동적 연결 라이브러리로 추가됩니다.
확인을 클릭하여 Win32 응용 프로그램 마법사를 시작합니다. Win32 응용 프로그램 마법사 대화 상자의 개요 페이지에서 다음을 클릭합니다.
Win32 응용 프로그램 마법사의 응용 프로그램 설정 페이지에 있는 응용 프로그램 종류에서 콘솔 응용 프로그램을 선택합니다.
Win32 응용 프로그램 마법사의 응용 프로그램 설정 페이지에 있는 추가 옵션에서 미리 컴파일된 헤더 확인란을 선택 취소합니다.
마침을 눌러 프로젝트를 만듭니다.
콘솔 응용 프로그램에서 클래스 라이브러리의 기능을 사용하려면
콘솔 응용 프로그램을 새로 만들면 빈 프로그램이 만들어집니다. 소스 파일의 이름은 앞에서 프로젝트에 대해 지정한 이름과 동일하게 설정됩니다. 이 예제에서 소스 파일의 이름은 MyExecRefsDll.cpp입니다.
동적 연결 라이브러리에서 만든 수학 루틴을 사용하려면 라이브러리를 참조해야 합니다. 이렇게 하려면 솔루션 탐색기에서 MyExecRefsDll 프로젝트를 선택한 다음 프로젝트 메뉴에서 **참조…**를 선택합니다. 속성 페이지 대화 상자에서 공용 속성 노드를 확장하고 프레임워크 및 참조를 선택한 다음 새 참조 추가… 단추를 선택합니다. 참조… 대화 상자에 대한 자세한 내용은 <Projectname> 속성 페이지 대화 상자, 공용 속성, 프레임워크 및 참조를 참조하십시오.
참조 추가 대화 상자가 표시됩니다. 이 대화 상자에는 참조할 수 있는 라이브러리의 전체 목록이 표시됩니다. 프로젝트 탭에는 현재 솔루션의 모든 프로젝트와 이 프로젝트에 포함된 라이브러리가 모두 나열됩니다. 프로젝트 탭에서 MathFuncsDll을 선택합니다. 그런 다음 확인을 클릭합니다.
동적 연결 라이브러리의 헤더 파일을 참조하려면 포함 디렉터리 경로를 수정해야 합니다. 이렇게 하려면 속성 페이지 대화 상자에서 구성 속성 노드, C/C++ 노드를 차례로 확장한 다음 일반을 선택합니다. 추가 포함 디렉터리 옆에 MathFuncsDll.h 헤더 파일의 위치에 대한 경로를 입력합니다.
런타임 이전까지는 실행 파일이 동적 연결 라이브러리를 로드하지 않습니다. MathFuncsDll.dll이 있는 위치를 시스템에 직접 알려야 합니다. PATH 환경 변수를 사용하면 됩니다. 속성 페이지 대화 상자에서 구성 속성 노드를 확장하고 디버깅을 선택합니다. 환경 옆에 PATH=<MathFuncsDll.dll 파일의 경로>를 입력합니다. 여기서 <MathFuncsDll.dll의 경로> 자리에는 MathFuncsDll.dll의 실제 위치를 대신 입력합니다. 확인을 클릭하여 모든 변경 내용을 저장합니다.
참고
실행 파일을 Visual Studio 대신 명령줄에서 실행하려면 명령 프롬프트에 set PATH=%PATH%;<MathFuncsDll.dll 파일의 경로>를 입력하여 PATH 환경 변수를 수동으로 업데이트해야 합니다. 여기서 <MathFuncsDll.dll 파일의 경로> 자리에는 MathFuncsDll.dll의 실제 위치를 대신 입력합니다.
이제 이 응용 프로그램에서 MyMathFuncs 클래스를 사용할 수 있습니다. MyExecRefsDll.cpp의 내용을 다음과 같은 코드로 바꿉니다.
// MyExecRefsDll.cpp // compile with: /EHsc /link MathFuncsDll.lib #include <iostream> #include "MathFuncsDll.h" using namespace std; int main() { double a = 7.4; int b = 99; cout << "a + b = " << MathFuncs::MyMathFuncs::Add(a, b) << endl; cout << "a - b = " << MathFuncs::MyMathFuncs::Subtract(a, b) << endl; cout << "a * b = " << MathFuncs::MyMathFuncs::Multiply(a, b) << endl; cout << "a / b = " << MathFuncs::MyMathFuncs::Divide(a, b) << endl; return 0; }
빌드 메뉴에서 솔루션 빌드를 선택하여 실행 파일을 빌드합니다.
응용 프로그램을 실행하려면
MyExecRefsDll이 기본 프로젝트로 선택되어 있는지 확인합니다. 솔루션 탐색기에서 MyExecRefsLib를 선택한 다음 프로젝트 메뉴에서 시작 프로젝트로 설정을 선택합니다.
프로젝트를 실행하려면 디버그 메뉴에서 디버깅하지 않고 시작을 선택합니다. 다음과 같은 결과가 출력됩니다.
a + b = 106.4 a - b = -91.6 a * b = 732.6 a / b = 0.0747475
다음 단계
이전: 재사용 가능한 코드 만들기(C++) | 다음: 연습: 정적 라이브러리 만들기 및 사용(C++)