Golang을 디컴파일할 수 있나요?
Golang은 바이너리 파일로 컴파일되기 때문에 Golang을 디컴파일할 수 없습니다. 바이너리 파일은 ASCII 및 확장 ASCII 문자로 작성된 데이터 또는 프로그램 명령이 포함된 파일이므로 이러한 파일에는 특수 형식과 컴퓨터 코드가 포함되어 있으므로 디컴파일할 수 없습니다. .
바이너리 파일의 이점
바이너리 파일을 사용하는 이유. 아마도 세 가지 이유가 있을 것입니다:
첫 번째는 바이너리 파일이 공간을 절약하고 문자 데이터를 저장할 때 둘 사이에 차이가 없다는 것입니다. 그러나 숫자, 특히 실수를 저장할 때 이진수는 공간을 더 절약합니다. 예를 들어 Real*4 데이터: 3.1415927을 저장하는 경우 텍스트 파일에는 9바이트가 필요하며 각각 다음을 저장합니다. 3. 1 4 1 5 9 2 7 ASCII 값, 바이너리 파일은 4바이트만 필요합니다(DB 0F 49 40)
두 번째 이유는 메모리에 계산에 관련된 데이터가 바이너리 비포맷 형식으로 저장되기 때문에 바이너리를 사용하여 메모리에 저장하는 것이 더 편리합니다. 파일. 텍스트 파일로 저장한 경우에는 변환 과정이 필요합니다. 데이터의 양이 많으면 둘 사이에 상당한 속도 차이가 발생합니다.
셋째, 비교적 정확한 일부 데이터의 경우 바이너리 저장소를 사용해도 유효한 비트가 손실되지 않습니다.
바이너리 파일 저장 방법
바이너리 파일 목록은 다음과 같습니다.
00000000h:0F 01 00 00 0F 03 00 00 12 53 21 45 58 62 35 34; !EXb54
00000010h:41 42 43 44 45 46 47 48 49 47 4B 4C 4D 4E 4F 50; ABCDEFGHIGKLMNOP
여기에 나열된 것은 UltraEdit(UE)에서 볼 수 있는 것입니다. 실제로 빨간색 부분만 파일 내용입니다. 앞의 것은 UE가 추가한 Line 번호이다. 다음은 UE가 문자로 해석하려는 참조입니다.
이 파일의 길이는 총 32바이트입니다. 각각 16바이트의 두 열로 표시됩니다. 사실 이것은 단지 UE의 디스플레이일 뿐입니다. 실제 파일에는 별도의 줄이 없습니다. 이 파일의 내용만 알고도 아무런 설명이 없으면 유용한 정보를 볼 수 없습니다.
다음에 설명을 규정하겠습니다. 처음 4바이트는 4바이트 정수 데이터(0F 01 00 00 16진수: 10Fh 10진수: 271)라고 믿습니다. 이 4바이트 뒤의 4바이트는 또 다른 4바이트의 정수 데이터입니다(0F 03 00 00 16진수: 30Fh 10진수: 783). 다음 4바이트(12 53 21 45)는 4바이트 실제 데이터를 나타냅니다: 2.5811919E+3. 다음 4바이트(58 62 35 34)는 실행 데이터의 또 다른 4바이트를 나타냅니다. 1.6892716E-7. 그리고 마지막 16바이트(41 42 43 44 45 46 47 48 49 47 4B 4C 4D 4E 4F 50)만 16바이트 문자열이라고 생각합니다(ABCDEFGHIGKLMNOP)
사실 바이너리 파일은 데이터를 저장하기만 하며, 데이터 형식은 그렇지 않습니다. 예를 들어 위의 9번째 바이트부터 16번째 바이트(12 53 21 45 58 62 35 34)를 지정하면 2개의 4바이트 실수형인 줄 알았는데 실제로는 8바이트 문자형(S)으로도 간주할 수 있습니다. !EXb54). 다음 16바이트 문자열(ABCDEFGHIGKLMNOP)은 8바이트 정수 2개, 4바이트 정수 4개, 8바이트 실수 유형 2개, 4바이트 실수 유형 4개 등으로 간주될 수도 있습니다.
따라서 바이너리 파일을 보면 그 의미를 정확히 알 수 없습니다. 데이터 저장 방법에 대한 설명이 필요합니다. 이 설명은 어떤 유형의 데이터가 어떤 바이트에서 어떤 바이트까지 있는지, 저장된 데이터의 의미는 무엇인지 알려줍니다. 그렇지 않으면 우리는 추측만 할 수 있거나 무력해질 수 있습니다.
추천 튜토리얼: "Go Tutorial"
위 내용은 Golang을 디컴파일할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!