- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在用 C 语言编写一个非侵入式保守 GC,我对其堆栈扫描阶段的正确性有些担忧。
具体来说,在没有启用编译器优化的情况下,它工作正常,因为每个局部变量(指向一个对象)都“可预测地”分配在堆栈上。在 -O3
中,GC 丢失了一些有效的引用,我认为这是由于编译器选择使用寄存器(而不是 GC 扫描的堆栈)来处理某些变量和函数参数通过并且 GC 还没有(还)被编程来处理它。 (如果您怀疑这仍然不应该发生并且我误解了问题的根源,请告诉我。)
除了一些基本要求(必须对 GC 对象使用 GC_malloc
而不是 malloc
,不要从非 GC 堆指向 GC 堆,并且,当然,不是显式调用 free
),GC 不应该有来自客户端代码或编译器的任何更多要求。因此,要求客户端代码提供任何额外的特殊模式不是一种选择。同样,强制使用此 GC 的程序使用特殊的编译器标志(抑制堆栈优化)进行编译,充其量应该是最后的选择。解决了这两个问题后,我的问题就形成了。
我正在尝试找到一种方法让 GC 无缝处理 -O3
情况(通过堆栈优化)。这是我的思路(假设,更准确地说):
问题 #1:所有我的 4 个假设都正确吗?
问题 #2:强制寄存器转储的最便携方法是什么?我发现一些消息来源声称一个简单的 setjmp
调用会产生这种效果。这是正确的吗?
最佳答案
Q1。是的,我相信您的所有四个陈述都是正确的(至少如果我们忽略编译器错误!)
Q2。 setjmp 将保存一些寄存器,但不一定是所有寄存器。但是,它应该足以满足您的目的,因为 setjmp 未保存的任何寄存器无论如何都应该保存在堆栈中。
如果有人在某处的缓冲区中存储了一些看起来像地址的东西,我想你的方案可能会出错,即使它不是。
您还必须记住,有时人们会用指针做一些“有趣”的事情。例如。
struct blah
{
size_t size;
char *file;
int line;
};
struct blah *p = malloc(sizeof(struct blah) + size);
... more lines of code goes here to fll in size, file and line in blah.
void *np = (p+1);
这意味着您存储的指针根本不指向 block 的开头。
关于c - 将寄存器转储到堆栈中以进行保守的堆栈扫描,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14512790/
使用 C# (VS2008) 和 WIA - 扫描到 TIFF 格式; 当我在平板或文档进纸器上使用扫描仪扫描 1 页时,该方法执行没有任何问题。当我将多个表单加载到进纸器时,扫描第一页后执行停止(保
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
给定一个列表 :: [(Foo, Bar)] ,我想在 Bar 上执行 scanl1 s,但保留他们的 Foo “标签”。 IE。我想要一个类型为 :: [(a, b)] -> ([b] -> [c]
我有一个 HBase 表,我需要从多个范围获取结果。例如,我可能需要从不同范围获取数据,例如第 1-6 行、100-150..... 我知道对于每次扫描,我可以定义开始行和停止行。但是如果我有 6 个
我看到了这段代码。我是 C 语言的新手,所以请原谅。 while下面的循环将继续循环 if i = SIZE,则 == 是无关紧要的,因为它根本不会被执行。如果 i 小于 SIZE 那么 scanf(
这是一个关于编译过程的相当技术性的问题ABAP代码。 我知道有ABAP解析器和扫描器类实际上调用 C 内核函数来完成实际工作。然后就是代码补全事务的功能,该事务以 ABAP 列表或 XML 的形式返回
给定以下程序: int main(){ float x = non_det_float(); float y = NAN; if (isnan(y) && x == 1.0f){
我在工作中使用由供应商生成的二维码。实际上我需要通过网站手动记录所有这些项目。 QR 码包含所有这些数据,所以我想创建一个自动执行操作的应用。 例如,二维码表示“AAA|BBB|CCC|123”。我想
我有一个像这样的字符串:@"ololo width: 350px jijiji width:440px ... text=12... "我想将@"width: "之后的所有数字替换为280。所以在扫描
我在玩 scanf 时遇到了一个小问题……更具体地说,我想读取整个输入,然后忽略其余部分。让我告诉你我的意思: #include int main(void) { int number_of
我正在使用 matlab/octave 创建扫描/线性调频信号,我的结束信号似乎以错误的频率结束。我该如何修复它,以便信号以正确的频率结束。 PS:我不能在 Octave 音程中使用 chirp 命令
我正在寻找一个可以扫描 WiFi 网络并打印所有 SSID 的程序。我试过 scapy 但我失败了。我正在使用 pyCharm 编辑器。 我试过这段代码: from scapy.all import
概述 Linux 完全是用于大型服务器的最流行和最安全的操作系统之一。尽管它被广泛使用,但它仍然容易受到网络攻击。黑客以服务器为目标,窃取有价值的信息。所以迫切需要开发反黑客方法来应对安全漏洞和恶
如何获取我的 Git 存储库的某种统计信息? 我目前在 BitBucket 中托管 Git 存储库,想查找以下详细信息: 提交总数 使用过的编程语言 每种编程语言的总代码行数 您认为这可以实现吗?还是
我目前正在使用以下代码来扫描作为申请表的一部分上传的文件: $safe_path = escapeshellarg($dir . $file); $command = '/usr/bin/clamsc
我在存储库中有十几个项目。存储库结构如下所示: / ------- + project1 +------- trunk +------- tags +----
我正在使用 Dynamo DB 并想使用过滤器扫描一个表。例如,是否可以使用全局二级索引仅扫描表中的特定行? 最佳答案 这不可能!扫描始终针对基表中的所有行,当您扫描索引表作为响应时,您将仅获得该索引
我正在尝试从这里使用 SOLStumbler:Accessing & Using the MobileWiFi.framework扫描 wifi 网络。我知道苹果不支持这一点,但它是用于教育目的和实验
我知道 iPhone 蓝牙功能在 3.0 之前无法通过 SDK 访问,但是需要多长时间才能找到该区域的设备?它取决于该区域的设备数量吗?如果范围内有大约 5 个设备,扫描发现所有设备是否需要花费 30
我正在使用Elasticsearch 6.2,并且有一些查询可以分析大量文档。我正在对索引内的一个字段进行排序。 Elasticsearch检查10.000个文档(默认配置值),然后将它们分页返回。
我是一名优秀的程序员,十分优秀!