Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 48. C/C++ JNI DLL을 Visual Studio로 디버깅하는 방법 [링크 복사], [링크+제목 복사],
조회: 35205
글쓴 사람
정성태 (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/
정성태

... 166  [167]  168  169  170  171  172  173  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
929정성태9/17/201026626웹: 15. IE 9 - 작업 표시줄의 웹 사이트 바로가기 사용자 정의 - JumpLists [3]파일 다운로드1
928정성태9/16/201030662VC++: 42. 쓰기 전용 파일(예: 로그 파일)의 동기화 방법파일 다운로드1
927정성태9/14/201040589VC++: 41. UTF-8 포맷의 INI 파일에 대한 GetPrivateProfile... API 사용 불가 [2]
926정성태9/9/201030076Team Foundation Server: 41. 빌드 스크립트에 Code Coverage 추가 [1]파일 다운로드1
925정성태9/8/201033807Team Foundation Server: 40. Visual Studio 2010 - Code Coverage 결과를 외부 XML 파일로 출력하는 명령행 도구 제작 [1]파일 다운로드1
924정성태9/6/201023772개발 환경 구성: 88. SCVMM이 설치된 도메인에 참여하지 않은 Hyper-V 호스트 추가
923정성태9/5/201030176오류 유형: 107. SCVMM Agent 설치 오류 - Failed to configure the WS-Management service.
922정성태9/4/201038836오류 유형: 106. Hyper-V 가상 머신의 네트워크 끊김 현상
921정성태9/2/201032669DDK: 2. Device Driver 응용 프로그램의 빌드 스크립트 [2]파일 다운로드1
920정성태9/1/201037680오류 유형: 105. WMI - The RPC server is unavailable [2]
919정성태8/30/201043790DDK: 1. Visual Studio 2010 - Device Driver 제작- Hello World 예제 [3]파일 다운로드1
918정성태8/28/201029178개발 환경 구성: 87. Hyper-V의 네트워크 유형 (3)
917정성태8/26/201024358개발 환경 구성: 86. "Routing and Remote Access"의 "Routing" 기능 활성화 방법
916정성태8/25/201023567개발 환경 구성: 85. 가상 네트워크에 LAN 어댑터 보이거나 감추는 방법
915정성태8/24/201041716개발 환경 구성: 84. Hyper-V의 네트워크 유형 (2)
913정성태8/22/201030869오류 유형: 104. Hyper-V 관리자 - VM 생성 오류 (VHD 생성 오류)
912정성태8/20/201032586.NET Framework: 183. 구조체 포인터 인자에 대한 P/Invoke 정의파일 다운로드1
911정성태8/19/201030199오류 유형: 103. System.Reflection.TargetException파일 다운로드1
910정성태8/19/201040959개발 환경 구성: 83. Hyper-V의 네트워크 유형 (1)
909정성태8/18/201035831오류 유형: 102. System.MissingMethodException
908정성태8/17/201026782개발 환경 구성: 82. Windows Virtual PC의 네트워크 유형 (3)
907정성태8/14/201024286개발 환경 구성: 81. Windows Virtual PC의 네트워크 유형 (2)
906정성태8/13/201032270개발 환경 구성: 80. Windows Virtual PC의 네트워크 유형 (1)
905정성태8/8/201035863Team Foundation Server: 39. 배치 파일로 팀 빌드 구성 [2]파일 다운로드1
904정성태8/8/201038265오류 유형: 101. SignTool Error: No certificates were found that met all the given criteria. [2]
903정성태8/6/201035145Team Foundation Server: 38. TFS 소스 코드 관리 기능 (4) - Branch
... 166  [167]  168  169  170  171  172  173  174  175  176  177  178  179  180  ...