- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试手写 Mach-O 可执行文件。加载命令共有三个:
LC_SEGMENT_64
正在加载__PAGEZERO
LC_SEGMENT_64
加载 __TEXT
,带有单个 __text
部分LC_UNIXTHREAD
带有适当设置的 rip
每个命令都与 mach/loader.h
和相关 header 中的结构匹配。 otool -l
按预期列出信息,并且不报告任何错误。从各方面来看,它都是一个格式良好的目标文件——但 OS X 10.10.5 终止了该任务 (SIGKILL)。
在 OS X 加载 Mach-O 可执行文件之前,会检查它的哪些功能?该信息位于何处?这些功能会随着版本的不同而变化吗? (经常被引用的“OS X ABI Mach-O 引用”显然丢失了。)
<小时/>这是一个partially annotated hexdump二进制文件。
otool
健全性检查(摘录):
$ otool -l machtest
machtest:
Load command 0
cmd LC_SEGMENT_64
cmdsize 72
segname __PAGEZERO
…
Load command 1
cmd LC_SEGMENT_64
cmdsize 152
segname __TEXT
…
Section
sectname __text
segname __TEXT
…
Load command 2
cmd LC_UNIXTHREAD
…
最佳答案
自 10.10.5 Yosemite 起,可执行文件的长度必须至少为 4096 字节 ( PAGE_SIZE
),否则将立即被终止。 @Siguza在XNU内核
exec_activate_image
函数https://github.com/apple/darwin-xnu/blob/0a798f6738bc1db01281fc08ae024145e84df927/bsd/kern/kern_exec.c#L1456
假设您想要一个仅使用系统调用的 64 位 macOS 可执行文件,您需要:
LC_SEGMENT_64
__PAGEZERO
(大小非零,名称可以是任何内容)LC_SEGMENT_64
__TEXT
(名称可以是任何内容;必须可读且可执行;部分是可选的)LC_UNIXTHREAD
这是本案例的 my example。
如果没有 dyld,你就不能做很多事情,所以如果你想使用它,最小集是:
LC_SEGMENT_64
__PAGEZERO
(大小非零)LC_SEGMENT_64
__TEXT
(名称可以是任何内容;必须可读且可执行;部分是可选的)LC_SEGMENT_64
__LINKEDIT
(必须是可写的,因为 dyld 需要可写段,在 ld
链接的二进制文件中,可写段通常为 __DATA
)LC_DYLD_INFO_ONLY
(指定实际 dyld
加载命令在可执行文件中的物理位置,通常可以在 __LINKEDIT
中找到它们,但没有限制这个)或有趣的是 LC_SYMTAB
相反,这将使实际的 dyld
在没有 LC_DYLD_INFO_ONLY
的情况下无法使用。LC_DYSYMTAB
(可以为空)LC_LOAD_DYLINKER
LC_MAIN
或 LC_UNIXTHREAD
LC_LOAD_DYLIB
(至少要加载一个实际的 dylib,最终依赖于 libSystem 或 libSystem 本身才能使 LC_MAIN
正常工作)此外,自 MacOS Monterey 12.3 起:
LC_SYMTAB
(如果使用LC_DYSYMTAB
,则现在需要)LC_UNIXTHREAD
和 LC_MAIN
在现代可执行文件中(自 10.7 Mountain Lion 起),LC_UNIXTHREAD
被 LC_MAIN
取代,后者需要 dyld
— 但 LC_UNIXTHREAD<从 10.12 Sierra 开始,任何可执行文件仍然支持/code>(并且应该在未来的 MacOS 版本中,因为它由
dyld
可执行文件本身用来实际启动)。
要使
加载的函数。dyld
正常工作,额外的步骤取决于绑定(bind)类型:加载时绑定(bind)
是最省力的方法,其中LC_DYLD_INFO_ONLY
指向指向可写段的有效dyld加载命令
就可以了。延迟绑定(bind)
还需要__TEXT
中额外的平台特定代码,该代码在加载时利用绑定(bind)dyld_stub_binder
来延迟加载dyld
的地址
还有其他类型的 dyld 绑定(bind)
,我在此不予介绍。
更多详细信息可以在这里找到:https://github.com/opensource-apple/dyld/blob/master/src/ImageLoaderMachO.cpp
关于mach-o - 加载 Mach-O 可执行文件需要什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39863112/
所以问题是:如何使用标准 C 库以跨平台方式实现简单的自检可执行文件? 在这里,我正在寻找技术,而不是特定的检查方法(如 CRC 或哈希码),但该技术可能包含更适合某些方法的元素(例如见下文)。 目的
我想构建一个 C++ 可执行文件,以便所有库也附加到可执行文件。构建这样一个可执行文件的方法是什么?因此,每当我在其他 PC(运行 Ubuntu)上使用 g++ 编译我的代码时,它不需要运行该可执行文
我在 Netbeans IDE 8.0.1 中编写了一个名为 SampleChat 的 Java GUI 程序,并使用“clean and build”功能创建了一个 jar 文件。 我进入 Netb
我有两个 DLL,一个用 native C++ 编写,另一个用 C++/CLI 编写。前者被注入(inject)到进程中,并在稍后的时间点加载后者。在调试时,我注意到 native DLL 的断点运行
如何访问可执行文件的机器代码(二进制文件)? 详情 我使用的是 Ubuntu (Linux) 我想访问 .exe 文件(文件遵循 PE 格式)的机器代码(二进制文件) 我正在使用 C 来实现 最佳答案
这个问题在这里已经有了答案: Run java jar file on a server as background process (4 个回答) 关闭1年前. 我正在使用命令提示符运行一个可执行
我的 jar 没有运行,我可以告诉它尝试运行,因为 log4j 文件设法创建日志文件夹,但没有任何 react 并且日志为空白。 我的问题是我在名为 bin 的文件夹中有 jar 文件,在名为 lib
我正在为我教育第一学期的编程考试创建一个程序。它应该向用户显示哥本哈根和其他 6 个城市(在其他时区)的时间。用户还应该能够将城市添加到列表中。我正在用 JAVA 编写程序(下面提供源代码)。当我从
我正在查看雅虎的 YUI 压缩器可执行 jar,他们有这个类,从 list 文件链接为“主类”: package com.yahoo.platform.yui.compressor; import j
问题是:从 Eclipse 导出时可执行 jar 中包含什么?我问这个问题是因为我想知道,例如,如果我在项目根目录中有一个图像,该图像是否会包含在导出中? 澄清:我说的是可运行的 jar 文件(已编辑
我知道这个问题已经被问了很多,并且我已经尝试了 eclipse(Kepler、Ganymede、Galileo)、fatJar、netbeans、blueJ、命令行和手册中的大约 20-30 种不同的
我从 IntelliJ 14.03 中的一个工件构建了一个 .jar。当我尝试在 JRE 中打开它时,没有任何反应。这只是一个简单的 GUI。 提前致谢。 最佳答案 在jar位置运行命令,例如 jav
我使用 eclipse 创建了一个可执行 JAR 文件。我在项目文件夹中有资源当框架打开时不会出现。我的意思是当我双击 JAR 文件时。更多的所以,在我尝试删除 JAR 文件后,我收到一条警告,表明该
我创建了一个尺寸相当大(125,000 kb)的可运行 Jar 文件。当我运行它时,该 jar 文件内的应用程序不会显示,但在任务管理器中 javaw.exe(应链接到该 jar 文件)进程正在运行。
我已经使用 Eclipse(文件->导出)为我的 java 程序创建了一个可执行 jar 文件。 当我双击 jar 时,它工作正常。将 jar 文件复制到另一台计算机(Windows)后,我收到错误“
我用 eclipse indigo 创建了一个可执行的 jar 文件,但是当我双击它时什么也没有发生。但是当我将 java -jar c:/dir/filename.jar 写入 cmd 时,它可以工
已关闭。这个问题是 off-topic 。目前不接受答案。 想要改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 已关闭10 年前。 Improve th
如何让该 Java 代码在 Eclipse 之外运行? import java.util.*; public class Calculations { public static void main(
今天我第一次启动 jar 文件时遇到问题。现在我知道(解压 jar 后)当我在 Eclipse 中导出并创建程序的 jar 包时,文本文件并没有出现。 为什么文本文件没有与类文件一起出现?我应该将它们
我不知道为什么,但是当我将项目导出到可执行 jar 文件时,有些东西并不像从 eclipse 运行程序一样。一帧不会打开,其中只包含文本。我有另一个内部框架,它是一个分割 Pane ,包含右侧面板上的
我是一名优秀的程序员,十分优秀!