>백엔드 개발 >C++ >Linux의 바이너리 실행 파일에서 어셈블리 코드를 추출하는 방법은 무엇입니까?

Linux의 바이너리 실행 파일에서 어셈블리 코드를 추출하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-10-31 08:49:30936검색

How to Extract Assembly Code from a Binary Executable in Linux?

Linux의 바이너리 실행 파일에서 어셈블리 코드 얻기

Linux의 바이너리 실행 파일에서 어셈블리 코드를 추출하려면 일반적으로 디스어셈블 도구를 사용합니다. GCC(GNU 컴파일러 컬렉션)는 디스어셈블리 기능을 직접 제공하지 않지만 동일한 개발 환경의 objdump 유틸리티는 필요한 기능을 제공합니다.

objdump를 사용하여 바이너리 실행 파일을 디스어셈블하려면 다음 단계를 따르세요.

<code class="Bash">$ objdump -d /path/to/binary</code>

이 명령은 실행 파일의 디스어셈블리를 생성하고 다음과 유사한 어셈블리 지침을 표시합니다.

080483b4 <main>:
 80483b4:   8d 4c 24 04             lea    0x4(%esp),%ecx
 80483b8:   83 e4 f0                and    xfffffff0,%esp
 80483bb:   ff 71 fc                pushl  -0x4(%ecx)
 80483be:   55                      push   %ebp
 80483bf:   89 e5                   mov    %esp,%ebp
 80483c1:   51                      push   %ecx
 80483c2:   b8 00 00 00 00          mov    x0,%eax
 80483c7:   59                      pop    %ecx
 80483c8:   5d                      pop    %ebp
 80483c9:   8d 61 fc                lea    -0x4(%ecx),%esp
 80483cc:   c3                      ret    
 80483cd:   90                      nop
 80483ce:   90                      nop
 80483cf:   90                      nop

위 내용은 Linux의 바이너리 실행 파일에서 어셈블리 코드를 추출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.