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

... [151]  152  153  154  155  156  157  158  159  160  161  162  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
1308정성태7/3/201227285.NET Framework: 330. IEnumerator는 언제나 읽기 전용일까?파일 다운로드1
1307정성태6/30/201229583개발 환경 구성: 154. Sysnet, Azure를 만나다. [5]
1306정성태6/29/201230028제니퍼 .NET: 22. 눈으로 확인하는 connectionManagement의 maxconnection 설정값 [4]
1305정성태6/28/201228366오류 유형: 157. IIS 6 - WCF svc 호출 시 404 Not Found 발생
1304정성태6/27/201229207개발 환경 구성: 153. sysnet 첨부 파일을 Azure Storage에 마이그레이션 [3]파일 다운로드1
1303정성태6/26/201228775개발 환경 구성: 152. sysnet DB를 SQL Azure 데이터베이스로 마이그레이션
1302정성태6/25/201230723개발 환경 구성: 151. Azure 웹 사이트에 사용자 도메인 네임 연결하는 방법
1301정성태6/20/201227005오류 유형: 156. KB2667402 윈도우 업데이트 실패 및 마이크로소프트 Answers 웹 사이트 대응
1300정성태6/20/201233556.NET Framework: 329. C# - Rabin-Miller 소수 생성방법을 이용하여 RSACryptoServiceProvider의 개인키를 직접 채워보자 [1]파일 다운로드2
1299정성태6/18/201234183제니퍼 .NET: 21. 제니퍼 닷넷 - Ninject DI 프레임워크의 성능 분석 [2]파일 다운로드2
1298정성태6/14/201235807VS.NET IDE: 72. Visual Studio에서 pfx 파일로 서명한 경우, 암호는 어디에 저장될까? [2]
1297정성태6/12/201232306VC++: 63. 다른 프로세스에 환경 변수 설정하는 방법파일 다운로드1
1296정성태6/5/201228864.NET Framework: 328. 해당 DLL이 Managed인지 / Unmanaged인지 확인하는 방법 - 두 번째 이야기 [4]파일 다운로드1
1295정성태6/5/201226287.NET Framework: 327. RSAParameters와 System.Numerics.BigInteger 이야기파일 다운로드1
1294정성태5/27/201250337.NET Framework: 326. 유니코드와 한글 - 유니코드와 닷넷을 이용한 한글 처리 [7]파일 다운로드2
1293정성태5/24/201230800.NET Framework: 325. System.Drawing.Bitmap 데이터를 Parallel.For로 처리하는 방법 [2]파일 다운로드1
1292정성태5/24/201224492.NET Framework: 324. First-chance exception에 대해 조건에 따라 디버거가 멈추게 할 수는 없을까? [1]파일 다운로드1
1291정성태5/23/201231389VC++: 62. 배열 초기화를 위한 기계어 코드 확인 [2]
1290정성태5/18/201236275.NET Framework: 323. 관리자 권한이 필요한 작업을 COM+에 대행 [7]파일 다운로드1
1289정성태5/17/201240621.NET Framework: 322. regsvcs.exe로 어셈블리 등록 시 시스템 변경 사항 [5]파일 다운로드2
1288정성태5/17/201227621.NET Framework: 321. regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (3) - Type Library파일 다운로드1
1287정성태5/17/201230427.NET Framework: 320. regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (2) - .NET 4.0 + .NET 2.0 [2]
1286정성태5/17/201239313.NET Framework: 319. regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (1) - .NET 2.0 + x86/x64/AnyCPU [5]
1285정성태5/16/201234418.NET Framework: 318. gacutil.exe로 어셈블리 등록 시 시스템 변경 사항파일 다운로드1
1284정성태5/15/201226849오류 유형: 155. Windows Phone 연결 상태에서 DRIVER POWER STATE FAILURE 블루 스크린 뜨는 현상
1283정성태5/12/201234488.NET Framework: 317. C# 관점에서의 Observer 패턴 구현 [1]파일 다운로드1
... [151]  152  153  154  155  156  157  158  159  160  161  162  163  164  165  ...