Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 48. C/C++ JNI DLL을 Visual Studio로 디버깅하는 방법 [링크 복사], [링크+제목 복사],
조회: 32698
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

C/C++ JNI DLL을 Visual Studio로 디버깅하는 방법

JNI DLL 파일만 만드는 경우 디버깅을 printf 방식으로 하는 경향이 있는데요. 저는 "F5 디버깅 (Start with debugging)"의 신봉자이기 때문에 그렇게 할 수는 없었습니다. ^^

그래서, JNI DLL을 사용하는 Java 프로그램을 만들어 달라고 해서 그걸로 Visual Studio에서 Break Point를 이용한 디버깅을 하게 되었습니다. 음... 하지만, 자바 개발자의 도움 없이는 일반적인 윈도우 응용 프로그램 개발자 입장에서는 디버깅 환경을 설정하는 것이 힘들겠더군요. 저도 시간이 지나면 잊어버릴 수 있으므로, 이참에 정리를 하는 것이 좋겠다는 생각이 들었습니다. ^^

우선, 해당 JNI DLL을 사용하는 자바 소스 코드가 다음과 같다고 가정해 보겠습니다.

package jennifer.runtime.jni;

public class SysJni {

    public static void main(String[] args) throws InterruptedException 
    {
        getSysCpu(f);
    }
}

위의 package를 어떻게 정의했느냐에 따라서 Visual studio의 디버깅 설정값이 바뀌므로 주의를 요하는데요. 일단, 위의 소스 코드를 빌드하면 "SysJni.class" 파일이 생성되는데 이를 JNI C/C++ 프로젝트에 다음과 같이 package에 나열된 문자열을 하나하나의 폴더로 변환해서 저장을 시켜줍니다.

debug_jni_in_vs_1.png

사실, Visual Studio C/C++ 프로젝트의 폴더 구조는 '논리적인 구조'일 뿐이어서 위와 같이 안 해도 되는데, 실제 '물리적인 구조'는 반드시 위와 같이 구성을 해서 맞춰주어야 합니다. (저는 가능한 Visual Studio 프로젝트에서 '논리적인 구조'와 '물리적인 구조'를 맞춰주는 것을 선호해서 저렇게 한 것입니다.)

참고로 위에 보면, "CallTest"라는 폴더를 하나 더 두었는데요. 구분을 하기 위해 폴더 하나를 더 만들었습니다.

자, 이렇게 한 후 C/C++ 프로젝트의 "Debugging" 옵션에서 다음과 같이 구성을 해줍니다.

debug_jni_in_vs_2.png

EXE 실행 파일 항목은 JRE에 포함된 java.exe를 지정하고, '명령행 인자'로는 패키지 명에 따라 생성한 폴더를 그대로 반영한 SysJni 클래스 파일 경로를 지정했습니다. (SysJni.class 파일인데, ".class" 확장자를 지정해서는 안 됩니다.) 또한 "Working Directory"도 중요한데, "CallTest"라는 폴더까지 함께 지정해 주었습니다.

마지막으로, 빌드된 JNI DLL 파일의 위치가 중요한데요. 다음 화면에서처럼 "Post-Build Event" 단계에서 CallTest 하위로 파일을 복사해 주는 작업을 지정해 주면 매 빌드 때마다 파일을 수작업으로 복사해 주는 불편함을 덜 수 있습니다.

debug_jni_in_vs_3.png

이것으로 준비는 모두 끝났습니다. ^^ 이제 "F5" 키를 눌러서 디버깅을 시작하면, 다음과 같이 BP를 걸어둔 곳에서 멈추기도 하고, ^^ 기타 모든 Visual Studio의 디버깅 기능을 이용하여 소스 코드를 꼼꼼하게 체크할 수 있습니다.

debug_jni_in_vs_4.png

(한 가지 주의할 것은 JNI 디버깅 시에는 DebugView를 띄우지 않는 것이 좋습니다. 제 경우에는 DebugView가 실행된 상태에서는 F5 디버깅 시에 "Hang" 현상이 발생했습니다.)




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 7/17/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2015-07-29 04시29분
정성태
2024-05-10 08시43분
Java - How to use the Foreign Function API in Java 22 to Call C Libraries
; https://ifesunmola.com/how-to-use-the-foreign-function-api-in-java-22-to-call-c-libraries/

"Writing C code in Java/Clojure: GraalVM specific programming"
; https://yyhh.org/blog/2021/02/writing-c-code-in-javaclojure-graalvm-specific-programming/
정성태

... 91  92  93  94  [95]  96  97  98  99  100  101  102  103  104  105  ...
NoWriterDateCnt.TitleFile(s)
11559정성태6/25/201828613개발 환경 구성: 384. 영문 설정의 Windows 10 명령행 창(cmd.exe)의 한글 지원 [6]
11558정성태6/24/201822244.NET Framework: 775. C# 7.3 - unmanaged(blittable) 제네릭 제약파일 다운로드1
11557정성태6/22/201821697.NET Framework: 774. C# - blittable 타입이란?파일 다운로드1
11556정성태6/19/201828575.NET Framework: 773. C# 7.3 - 구조체의 고정 크기를 갖는 fixed 배열 필드에 대한 직접 접근 가능 [1]파일 다운로드1
11555정성태6/18/201820268.NET Framework: 772. C# 7.3 - 사용자 정의 타입에 fixed 적용 가능(Custom fixed)파일 다운로드1
11554정성태6/17/201822286.NET Framework: 771. C# 7.3 - 자동 구현 속성에 특성 적용 가능(Attribute on backing field)
11553정성태6/15/201821881.NET Framework: 770. C# 7.3 - 개선된 메서드 선택 규칙 3가지(Improved overload candidates)파일 다운로드1
11552정성태6/15/201823864.NET Framework: 769. C# 7.3에서 개선된 문법 4개(Support == and != for tuples, Ref Reassignment, Constraints, Stackalloc initializers)파일 다운로드1
11551정성태6/14/201820449개발 환경 구성: 383. BenchmarkDotNet 사용 시 주의 사항
11550정성태6/13/201820346.NET Framework: 768. BenchmarkDotNet으로 Span<T> 성능 측정 [2]
11549정성태6/13/201821986개발 환경 구성: 382. BenchmarkDotNet에서 생성한 BuildPlots.R 파일을 실행하는 방법
11548정성태6/13/201819235오류 유형: 470. .NET Core + BenchmarkDotNet 실행 시 프레임워크를 찾지 못하는 문제
11547정성태6/13/201824322.NET Framework: 767. BenchmarkDotNet 라이브러리 소개파일 다운로드1
11546정성태6/12/201824486.NET Framework: 766. C# 7.2의 특징 - GC 및 메모리 복사 방지를 위한 struct 타입 개선 [9]파일 다운로드1
11545정성태6/11/201822746오류 유형: 469. .NET Core 프로젝트를 Visual Studio에서 실행 시 System.BadImageFormatException 발생하는 경우 [1]
11544정성태6/10/201822325.NET Framework: 765. C# 7.2 - 숫자 리터럴의 선행 밑줄과 뒤에 오지 않는 명명된 인수
11543정성태6/9/201821896.NET Framework: 764. C# 7.2 - private protected 접근자 추가파일 다운로드1
11542정성태6/9/201860298개발 환경 구성: 381. Azure Web App 확장 예제 - Remove Custom Headers
11541정성태6/9/201819491개발 환경 구성: 380. Azure Web App 확장 배포 방법 [1]
11540정성태6/9/201820273개발 환경 구성: 379. Azure Web App 확장 예제 제작 [2]
11539정성태6/8/201820053.NET Framework: 763. .NET Core 2.1 - Tiered Compilation 도입파일 다운로드1
11538정성태6/8/201819338.NET Framework: 762. .NET Core 2.1 - 확장 도구(Tools) 관리 [1]
11537정성태6/8/201823855.NET Framework: 761. C# - SmtpClient로 SMTP + SSL/TLS 서버를 이용하는 방법 [5]
11536정성태6/7/201821475.NET Framework: 760. Microsoft Build 2018 - The future of C# 동영상 내용 정리 [1]파일 다운로드1
11535정성태6/7/201823304.NET Framework: 759. C# - System.Span<T> 성능 [1]
11534정성태6/6/201829073.NET Framework: 758. C# 7.2 - Span<T> [6]
... 91  92  93  94  [95]  96  97  98  99  100  101  102  103  104  105  ...