DLL에는 무엇이 있으며 어떻게 작동합니까?


86

나는 항상 내 C # 코드에서 DLL을 참조하고 있지만 그것들은 내가 명확히하고 싶은 미스터리로 남아있다. 이것은 DLL에 관한 일종의 두뇌 덤프입니다.

DLL이 동적으로 연결된 라이브러리라는 것을 이해합니다. 즉, 다른 프로그램이 "기능"을 얻기 위해 런타임에이 라이브러리에 액세스 할 수 있음을 의미합니다. 그러나 Web.dllBusiness.dll( Web.dll는 프런트 엔드 기능이며 Business.dll형식 및 메서드에 대한 참조)가 있는 다음 ASP.NET 프로젝트를 고려하십시오 .

  1. 어떤 시점에서 Web.dll동적으로 연결 Business.dll됩니까? Word 등을 사용할 때 겉보기에 작은 작업으로 인해 Windows HDD에서 많은 스 래싱이 발생하고 Word가 다른 DLL의 기능에서 동적으로 연결되고 있다고 생각합니까?

    1a. 또한 DLL (OS 또는 .NET 프레임 워크와 같은 일부 런타임 프레임 워크)을로드하고 링크하는 것은 무엇입니까?

    1b. "연결"과정은 무엇입니까? 호환성 확인이 이루어 집니까? 동일한 메모리에로드 하시겠습니까? 실제로 연결이란 무엇을 의미합니까?

  2. 실제로 DLL에서 코드를 실행하는 것은 무엇입니까? 프로세서에 의해 실행됩니까 아니면 프로세서가 DLL 내부의 코드를 이해하기 전에 다른 변환 또는 컴파일 단계가 있습니까?

    2a. C # .NET으로 빌드 된 DLL의 경우이를 실행하는 것은 무엇입니까? .NET 프레임 워크 또는 운영 체제 직접?

  3. Linux의 DLL이 Windows 시스템에서 작동합니까 (존재하는 경우), 아니면 운영 체제에 따라 달라 집니까?

  4. DLL은 특정 프레임 워크에 고유합니까? C # .NET을 사용하여 빌드 된 DLL을 예를 들어 Borland C ++로 빌드 된 DLL에서 사용할 수 있습니까?

    4a. 4에 대한 답이 "아니오"이면 DLL의 요점은 무엇입니까? 다양한 프레임 워크가 링크 된 파일에 대해 고유 한 형식을 사용하지 않는 이유는 무엇입니까? 예를 들어, .NET에 내장 된 .exe는 .abc의 파일 유형이 코드에 링크 될 수 있다는 것을 알고 있습니다.

  5. Web.dll/ Business.dll예제로 돌아가서 참조해야하는 클래스 유형의 고객을 가져 Business.dll옵니다 Web.dll. 이것은 Business.dll고객 클래스가 실제로 무엇인지에 대한 일종의 사양 을 포함하고 있음을 의미합니다 . Business.dll예를 들어 Delphi에서 파일을 컴파일 했다면 C #이이를 이해하고 고객 클래스를 생성 할 수 있습니까? 아니면 일종의 헤더 정보 또는 "다른 Delphi DLL에서만 사용할 수 있습니다." ?

    5a. 방법에도 동일하게 적용됩니다. CreateInvoice()DLL에 메서드를 작성하고 C ++로 컴파일 한 다음 C #에서 액세스하여 실행할 수 있습니까? 이 작업을 중단하거나 허용하는 것은 무엇입니까?

  6. DLL 하이재킹의 주제에서 대체 (불량) DLL은 하이재킹되는 것과 동일한 메서드 서명 및 유형을 포함해야합니다. 원래 DLL에서 사용 가능한 메서드를 찾을 수 있다면 이것이 어렵지 않을 것이라고 생각합니다.

    6a. 내 C # 프로그램에서 다른 DLL에 액세스 할 수 있는지 결정하는 것은 무엇입니까? 납치 된 DLL에 원본과 동일한 메서드 및 유형이 포함되어 있지만 다른 언어로 컴파일 된 경우 작동합니까?

DLL 가져 오기 및 DLL 등록이란 무엇입니까?


21
이 질문은 역사상 가장 긴 대답을 요구할 수 있습니다.
Matti Virkkunen

4
12 개의 별도 질문이어야합니다.
Henk Holterman

2
이것은 멋진 질문이지만 @Chaos 및 @Matti에 정말 동의합니다. 이 질문은 더 많은 초점이 필요하며 여러 질문으로 나눌 수 있습니다.
Chris Thompson

3
내가 글을 썼을 때 그것은 약간의 두뇌 덤프였습니다 + 한 영역에서 지식을 중앙 집중화하고 싶었습니다 :)
Remotec

1
지금 쯤이면 커뮤니티 위키 여야합니다.
leppie 2013-07-13

답변:


74

우선, 매우 다른 두 종류의 DLL 간의 차이점을 이해해야합니다. Microsoft는 .NET (관리 코드) 및 네이티브 코드와 함께 동일한 파일 확장명 (.exe 및 .dll)을 사용하기로 결정했지만 관리 코드 DLL과 네이티브 DLL은 내부에서 매우 다릅니다.

1) web.dll은 어떤 시점에서 business.dll에 동적으로 연결됩니까? Word 등을 사용할 때 겉보기에 작은 작업으로 인해 Windows HDD에서 많은 스 래싱이 발생 하고이 Word가 작동하지 않고 다른 DLL의 기능에서 동적으로 연결되는 것으로 생각합니까?

1) .NET의 경우 DLL에서 액세스를 시도하는 첫 번째 메서드가 실행될 때 일반적으로 요청시 DLL이로드됩니다. 이것이 DLL을로드 할 수없는 경우 코드의 어느 곳에서나 TypeNotFoundExceptions를 얻을 수있는 이유입니다. Word와 같은 것이 갑자기 HDD에 많이 액세스하기 시작하면 스와핑 (스왑 된 데이터를 RAM의 공간을 확보하기 위해 디스크로 가져옴) 일 수 있습니다.

1a) 추가적으로 DLL (O / S 또는 .Net 프레임 워크와 같은 일부 런타임 프레임 워크)을로드하고 링크하는 것은 무엇입니까?

1a) 관리 DLL의 경우 .NET 프레임 워크가로드되고 JIT가 컴파일 (.NET 바이트 코드를 네이티브 코드로 컴파일)하고 DLL을 연결합니다. 네이티브 DLL의 경우 DLL을로드하고 연결하는 것은 운영 체제의 구성 요소입니다 (네이티브 DLL에는 이미 네이티브 코드가 포함되어 있으므로 컴파일이 필요하지 않습니다).

1b) "연결"과정은 무엇입니까? 호환성이 있는지 확인합니까? 동일한 메모리에로드 하시겠습니까? 실제로 연결이란 무엇을 의미합니까?

1b) 링크는 호출 코드의 참조 (예 : 메서드 호출)가 DLL의 심볼 (예 : 메서드)에 대한 참조가 DLL에있는 사물의 실제 주소로 대체되는 경우입니다. 이것은 DLL에있는 사물의 최종 주소를 메모리로로드하기 전에 알 수 없기 때문에 필요합니다.

2) 실제로 DLL에서 코드를 실행하는 것은 무엇입니까? 프로세서에 의해 실행됩니까 아니면 프로세서가 DLL 내부의 코드를 이해하기 전에 다른 변환 또는 컴파일 단계가 있습니까?

2) Windows에서 .exe 파일과 .dll 파일은 상당히 동일합니다. 네이티브 .exe 및 .dll 파일에는 네이티브 코드 (프로세서가 실행하는 것과 동일한 항목)가 포함되어 있으므로 번역 할 필요가 없습니다. 관리되는 .exe 및 .dll 파일에는 첫 번째 JIT 컴파일 (네이티브 코드로 변환) 된 .NET 바이트 코드가 포함되어 있습니다.

2a) C # .net에서 빌드 된 DLL의 경우 이것을 실행하는 것은 무엇입니까? .Net 프레임 워크 또는 운영 체제 직접?

2a) 코드가 JIT 컴파일 된 후에는 다른 코드와 똑같은 방식으로 실행됩니다.

3) Linux의 DLL이 Windows 시스템에서 작동합니까 (존재하는 경우) 아니면 운영 체제에 특정한 것입니까?

3) 관리 DLL은 두 플랫폼의 프레임 워크가 최신 상태이고 DLL을 작성한 사람이 네이티브 호출을 사용하여 고의로 호환성을 깨뜨리지 않는 한 그대로 작동 할 수 있습니다. 네이티브 DLL은 형식이 다르기 때문에 그대로 작동하지 않습니다 (둘 다 동일한 프로세서 플랫폼 용인 경우 내부의 기계어 코드가 동일하더라도). 그런데 Linux에서 "DLL"은 .so (공유 개체) 파일로 알려져 있습니다.

4) 특정 프레임 워크에 고유합니까? C # .Net을 사용하여 빌드 된 DLL을 Borland C ++로 빌드 된 DLL에서 사용할 수 있습니까 (예제 만 해당)?

4) 관리 DLL은 .NET 프레임 워크에 특화되어 있지만 자연스럽게 호환되는 모든 언어와 함께 작동합니다. 모든 사람이 동일한 규칙 (호출 규칙 (기계 코드 수준에서 함수 인수가 전달되는 방식), 기호 이름 지정 등)을 사용하는 한 네이티브 DLL은 호환됩니다.

5) web.dll / business.dll 예제로 돌아갑니다. 클래스 유형의 고객을 얻으려면 web.dll에서 business.dll을 참조해야합니다. 이것은 business.dll에 고객 클래스가 실제로 어떤 종류인지에 대한 사양이 포함되어 있음을 의미합니다. 내 business.dll 파일을 Delphi가 C #에서 이해하고 고객 클래스를 생성 할 수 있다고 말한 경우-아니면 일종의 헤더 정보 또는 "이봐 죄송합니다. 다른 delphi dll에서만 사용할 수 있습니다." .

5) 관리 DLL에는 포함 된 모든 클래스, 메서드, 필드 등에 대한 전체 설명이 포함되어 있습니다. AFAIK Delphi는 .NET을 지원하지 않으므로 .NET에서 간단하게 사용할 수없는 네이티브 DLL을 생성합니다. PInvoke를 사용하여 함수를 호출 할 수 있지만 클래스 정의는 찾을 수 없습니다. 델파이를 사용하지 않아서 DLL과 함께 유형 정보를 저장하는 방법을 모르겠습니다. 예를 들어 C ++는 유형 선언을 포함하고 DLL과 함께 배포되어야하는 헤더 (.h) 파일에 의존합니다.

6) DLL 하이재킹의 주제에 대해 대체 (나쁜) DLL에는 하이재킹되는 것과 같은 정확한 메서드 서명 유형이 포함되어야합니다. 원래 DLL에서 어떤 방법을 사용할 수 있는지 알 수 있다면 이것이 어렵지 않을 것이라고 생각합니다.

6) 실제로 DLL을 쉽게 전환 할 수 있다면 어렵지 않습니다. 이를 방지하기 위해 코드 서명을 사용할 수 있습니다. 누군가 서명 된 DLL을 교체하려면 서명 키를 알아야하는데,이 키는 비밀로 유지됩니다.

6a) 여기에 약간의 반복 질문이 있지만 C # 프로그램에서 다른 DLL에 액세스 할 수 있는지 결정하는 내용으로 돌아갑니다. 납치 된 DLL에 원본과 동일한 메서드와 유형이 포함되어 있지만 다른 언어로 컴파일 된 경우 작동합니까?

6a) .NET 언어로 만든 관리 DLL 인 한 작동합니다.

  • DLL 가져 오기 란 무엇입니까? 및 dll 등록?

"DLL 가져 오기"는 많은 것을 의미 할 수 있으며 일반적으로 DLL 파일을 참조하고 그 안에있는 것을 사용하는 것을 의미합니다.

DLL 등록은 DLL 파일을 COM 구성 요소로 전역 적으로 등록하여 시스템의 모든 소프트웨어에서 사용할 수 있도록 Windows에서 수행되는 작업입니다.


3
.NET이 DLL을 번역 할 수 있으므로 COM (Common Object Model)을 이해 / 사용하는 모든 기본 프로그램과 호환되도록 # 4에 추가하겠습니다. 아주 좋은 대답입니다.
MerickOWA

7

.dll 파일에는 응용 프로그램에서 사용할 수있는 컴파일 된 코드가 포함되어 있습니다.

때로는 .dll을 컴파일하는 데 사용되는 도구가 중요하지 않은 경우도 있습니다. 프로젝트에서 .dll을 참조 할 수 있다면 .dll의 노출 된 함수를 코딩하는 데 사용 된 도구는 중요하지 않습니다.

컴파일 타임에 링크하는 클래스와 같이 정적으로 링크 된 라이브러리와 달리 링크는 런타임에 발생합니다.

.dll은 자신이 작성하고 싶지 않은 애플리케이션에 필요한 것을 제공하는 블랙 박스로 생각할 수 있습니다. 예, .dll의 서명을 이해하는 사람이 내부에 다른 코드가 포함 된 다른 .dll 파일을 만들 수 있으며 호출 응용 프로그램이 그 차이를 알 수 없습니다.

HTH


6

1) web.dll은 어떤 시점에서 business.dll에 동적으로 연결됩니까? Word 등을 사용할 때 겉보기에 작은 작업으로 인해 Windows HDD에서 많은 스 래싱이 발생 하고이 Word가 작동하지 않고 다른 DLL의 기능에서 동적으로 연결되는 것으로 생각합니까?

1) 링크와 로딩이 헷갈 린다고 생각합니다. 링크는 요청 된 내용이 사용 가능한지 확인하기 위해 모든 견제와 균형을 테스트 할 때입니다. 로드 시간에 dll의 일부는 메모리로로드되거나 페이지 파일로 스왑됩니다. 이것은 당신이보고있는 HD 활동입니다.

동적 연결은 정적 연결에서 모든 개체 코드가 연결 시간에 기본 .exe에 저장된다는 점에서 정적 연결과 다릅니다. 동적 연결을 사용하면 개체 코드가 별도의 파일 (dll)에 저장되고 .exe와 다른 시간에로드됩니다.

동적 연결은 암시 적 (즉, 가져 오기 라이브러리가있는 앱 연결)이거나 명시적일 수 있습니다 (예 : 앱이 LoadLibrary (ex)를 사용하여 dll을로드 함).

암시적인 경우 / DELAYLOAD를 사용하여 앱이 실제로 필요할 때까지 dll로드를 연기 할 수 있습니다. 그렇지 않으면 프로세스 초기화의 일부로 적어도 일부가로드됩니다 (프로세스 주소 공간에 매핑 됨). dll은 프로세스가 활성 상태 인 동안 언로드되지 않도록 요청할 수도 있습니다.

COM은 LoadLibrary를 사용하여 COM dll을로드합니다. 암시적인 경우에도 시스템은 LoadLibrary와 유사한 것을 사용하여 프로세스 시작 또는 처음 사용할 때 dll을로드합니다.

2) 실제로 DLL에서 코드를 실행하는 것은 무엇입니까? 프로세서에 의해 실행됩니까 아니면 프로세서가 DLL 내부의 코드를 이해하기 전에 다른 변환 또는 컴파일 단계가 있습니까?

2) DLL은 .exes와 같은 개체 코드를 포함합니다. dll 파일의 형식은 exe 파일의 형식과 거의 동일합니다. 두 파일의 헤더에 다른 비트가 하나 뿐이라고 들었습니다.

C # .net에서 빌드 된 DLL의 경우 .Net 프레임 워크가이를 실행합니다.

3) Linux의 DLL이 Windows 시스템에서 작동합니까 (존재하는 경우) 아니면 운영 체제에 특정한 것입니까?

3) DLL은 플랫폼에 따라 다릅니다.

4) 특정 프레임 워크에 고유합니까? C # .Net을 사용하여 빌드 된 DLL을 Borland C ++로 빌드 된 DLL에서 사용할 수 있습니까 (예제 만 해당)?

4) Dlls는 특별한주의를 기울이거나 추가 글루 코드가 작성되면 다른 프레임 워크와 상호 운용 될 수 있습니다.

Dlls는 회사가 중복 기능이있는 여러 제품을 판매 할 때 매우 유용합니다. 예를 들어, 회사에서 30 개 이상의 서로 다른 제품에서 사용되는 래스터 I / O dll을 유지 관리합니다. 여러 제품이 설치된 경우 dll을 한 번만 업그레이드하면 모든 제품을 새 래스터 형식으로 업그레이드 할 수 있습니다.

5) web.dll / business.dll 예제로 돌아갑니다. 클래스 유형의 고객을 얻으려면 web.dll에서 business.dll을 참조해야합니다. 이것은 business.dll에 고객 클래스가 실제로 어떤 종류인지에 대한 사양이 포함되어 있음을 의미합니다. 내 business.dll 파일을 Delphi가 C #에서 이해하고 고객 클래스를 생성 할 수 있다고 말한 경우-아니면 일종의 헤더 정보 또는 "이봐 죄송합니다. 다른 delphi dll에서만 사용할 수 있습니다." .

5) 플랫폼에 따라 dll의 기능은 .h 파일, .tlb 파일 또는 .net의 다른 방법을 통해 다양한 방식으로 제공됩니다.

6) DLL 하이재킹의 주제에 대해 대체 (나쁜) DLL에는 하이재킹되는 것과 같은 정확한 메서드 서명 유형이 포함되어야합니다. 원래 DLL에서 어떤 방법을 사용할 수 있는지 알 수 있다면 이것이 어렵지 않을 것이라고 생각합니다.

6) dumpbin / exports 및 dumbin / imports는 .exe 및 .dll에서 사용할 수있는 흥미로운 도구입니다.


3) DLL은 플랫폼에 따라 다릅니다
Henk Holterman
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.