Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 48. C/C++ JNI DLL을 Visual Studio로 디버깅하는 방법 [링크 복사], [링크+제목 복사],
조회: 32580
글쓴 사람
정성태 (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)
603정성태10/15/200824124    답변글 디버깅 기술: 18.1. 소스 서버 구성, 그 외의 이야기
599정성태10/5/200830078디버깅 기술: 17. TFS Team Build + Symbol Server [1]
598정성태10/3/200820057VS.NET IDE: 57. VS.NET 2008 - 다중 프로젝트에서 단일 SNK를 사용하는 방법
597정성태10/2/200818737Team Foundation Server: 25. VSTS 2008의 Build Explorer
596정성태10/2/200825488오류 유형: 58. WPF : 드롭다운 유형의 ComboBox가 펼쳐지지 않는 문제
595정성태10/1/200833068디버깅 기술: 16. Watson Bucket 정보를 이용한 CLR 응용 프로그램 예외 분석 [2]
594정성태9/22/200821048.NET Framework: 104. Win32Exception 클래스 소개
591정성태7/24/200817822오류 유형: 57. VS.NET 2008 TFC - 체크인 시에 비프 음과 함께 정지되는 현상
592정성태7/28/200817800    답변글 오류 유형: 57.1. VS.NET 2008 TFC - 체크인 시에 비프 음과 함께 정지되는 현상 [1]
590정성태7/20/200823624.NET Framework: 103. WPF - ControlTemplate을 코드에서 다뤄보기 [1]
589정성태6/17/200820517.NET Framework: 102. COM 개체의 이벤트를 구독하는 코드 제작 [1]
588정성태6/13/200822376VC++: 35. COM 이벤트에서 반환값을 가진 콜백 정의
587정성태6/10/200827148VS.NET IDE: 56. C#에서 아쉬운 __DATE__, __TIME__ 매크로 [2]
586정성태6/4/200824777오류 유형: 56. WPF 디자이너 - The string was not recognized as a valid DateTime [2]
585정성태6/4/200832888.NET Framework: 101. WPF - ActiveX 컨트롤 호스팅하는 방법 [2]
582정성태5/16/200824737오류 유형: 55. Windowless ActiveX controls are not supported
580정성태4/24/200823820VC++: 34. 64비트 윈도우즈에서의 이벤트 후킹
579정성태4/24/200823660VC++: 33. 변환 후의 RGS 파일 내용을 얻는 방법
577정성태4/16/200824546.NET Framework: 100. XML Serializer를 이용한 값 복사 [5]
575정성태4/7/200821691오류 유형: 54. TFS Source Control - 명령을 사용할 수 없음 [2]
574정성태3/31/200819959오류 유형: 53. TFS 연결 오류 - The workspace [...] exists on computer [...]
573정성태3/25/200823681Windows: 31. TS Web Access와 UAC [1]
570정성태3/17/200823052오류 유형: 52. TFS 연결 오류 - TF31001 [2]
569정성태3/16/200823963Team Foundation Server: 24. TFS 2008로 마이그레이션 (2) [2]
566정성태2/28/200825121.NET Framework: 99. AppDomain.GetEntryAssembly()를 우회하는 방법파일 다운로드1
564정성태2/16/200824668Windows: 30. TS Web Access + Vista SP1 [2]
... 166  167  168  169  170  171  172  173  174  175  [176]  177  178  179  180  ...