- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
)进行比较。实际上,这意味着在形状上进行比较 if (start_object ,>=)具有以-6ren">
仅当指针都指向同一个聚合对象(结构,数组或 union )时,才由C标准定义将指针与关系运算符(例如<
,<=
,>=
或>
)进行比较。实际上,这意味着在形状上进行比较
if (start_object <= my_pointer && my_pointer < end_object+1) {
if (1) {
There is still one assumption, however, that pointers to different blocks returned by
sbrk
can be meaningfully compared. This is not guaranteed by the standard, which permits pointer comparisons only within an array. Thus this version ofmalloc
is portable only among machines for which general pointer comparison is meaningful.
malloc
used in glibc
也做同样的事情!
malloc
之类的功能,并且作业说明要求我们使用K&R代码,但我们必须替换调用
sbrk
来调用
mmap
!
sbrk
调用的指针可能是未定义的,但这也只是一点点可疑,因为您有某种直觉,即返回的指针应该来自相同的内存区域。据我所知,不同的
mmap
调用返回的指针甚至不能保证彼此遥远相似,并且跨mmap调用合并/合并内存块应该是非常非法的(而且
glibc
似乎避免了这种情况,只能通过合并来实现)由
sbrk
返回的内存或在
mmap
页面内部(而不是跨页面)的内存),但是分配需要这样做。
sbrk
的比较是否优化,以及glibc
会执行哪些操作,使他们摆脱它。 最佳答案
语言律师的答案(我相信)可以在C99标准的6.5.8.5节中找到(或更准确地说,来自ISO/IEC 9899:TC3委员会草案— 2007年9月7日,WG14/N1256,该文本几乎相同,但我不知道)关于关系运算符(即<
,<=
,>
,>=
)具有以下内容:
When two pointers are compared, the result depends on the relative locations in the address space of the objects pointed to. If two pointers to object or incomplete types both point to the same object, or both point one past the last element of the same array object, they compare equal. If the objects pointed to are members of the same aggregate object, pointers to structure members declared later compare greater than pointers to members declared earlier in the structure, and pointers to array elements with larger subscript values compare greater than pointers to elements of the same array with lower subscript values. All pointers to members of the same union object compare equal. If the expression
P
points to an element of an array object and the expressionQ
points to the last element of the same array object, the pointer expressionQ+1
compares greater thanP
. In all other cases, the behavior is undefined.
NULL
,要么是通过使用
&
获取对象的地址派生的,或者是通过指针算术或某些函数的结果派生的。在有关情况下,它们是由
sbrk
或
mmap
系统调用的结果派生的。这些系统调用真正返回了什么?在寄存器级别,它们返回一个大小为
uintptr_t
(或
intptr_t
)的整数。实际上,正是系统调用接口(interface)将它们强制转换为指针。正如我们所知道的,指针和
uintptr_t
(或
intptr_t
)之间的强制转换是通过bijective类型定义的,我们知道我们可以将指针转换为
uintptr_t
(例如)并进行比较,这将在指针上加上
well order relation。 Wikipedia链接提供了更多信息,但是从本质上讲,这将确保正确定义每个比较以及其他有用的属性(例如
a<b
和
b<c
意味着
a<c
)。 (我也不能选择完全任意的顺序,因为它需要满足C99§6.5.8.5的其他要求,这几乎让我只有
intptr_t
和
uintptr_t
作为候选者。)
if ((uintptr_t)start_object <= (uintptr_t)my_pointer && (uintptr_t)my_pointer < (uintptr_t)(end_object+1)) {
uintptr_t
而不是
intptr_t
。为什么这是正确的选择?实际上,为什么我没有选择一个相当奇怪的顺序,例如反转位并进行比较?这里的假设是我选择与内核相同的顺序,特别是我对
<
的定义(由该顺序给出)是这样的,即任何分配的内存块的开始和结束都将始终为
start < end
。在我所知道的所有现代平台上,都没有“回绕”(例如,内核不会分配从
0xffff8000
开始到
0x00007ffff
结束的32位内存)-尽管请注意类似的回绕
has been exploited in the past。
<
或
>
,并且只有相等时才可以在偏移量上使用
<
或
>
。只要C99§6.5.8.5中的所有结构都在同一段中,这将是完全合法的。但它不会像人们期望的那样在段之间起作用,因为
1000:1234
(等于内存地址中的
1010:1134
)看起来会小于
1010:0123
。此处的
mmap
可能会在不同的段中返回结果。类似地,可以想到另一种内存模型,其中段寄存器实际上是选择器,并且指针比较使用处理器比较指令来比较内存地址,如果使用了无效的选择器或段外部的偏移量,则该内存地址将中止。
Whether or not comparing pointers from different calls to
sbrk
may be optimised away, andIf so, what glibc does that lets them get away with it.
start_object
等实际上是
void *
,然后可以优化计算(即可以执行您想要的操作),但不能保证这样做,因为行为是不确定的。如果内核使用与强制转换隐含的相同的良好顺序,则强制转换将保证这样做。
glibc
依赖于C编译器的行为,这在技术上不是必需的,但很有可能(根据以上所述)。
header *
指针与
<
的比较(据我所知,
void *
指针与
<
的比较始终是UB),这可能来自于单独的
sbrk()
调用。
关于c - 是什么使glibc malloc可以比较来自不同 "objects"的指针?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40809553/
我想使用 NetworkX Graph 对象作为 Python dict 中的键。但是,我不希望默认的比较行为(即通过对象的地址)。相反,我希望同构图是 dict 中相同元素的键。 此行为是否已在某处
这个问题已经有答案了: What is the most effective way for float and double comparison? (33 个回答) 已关闭 7 年前。 在您认为我
我正在学习 C 编程,为了练习,我找到了一个需要解决的任务。这有点像一个游戏,有人选择一个单词,其他人猜测字母。我必须检查有多少给定的单词可能是所选单词的正确答案。 输入: 3 3//数字 n 和 m
我两天前开始学习C,在做作业时遇到了问题。我们的目的是从字符数组中获取字符列表,并通过计算连续字符并将其替换为数字来缩短它。对“a4b5c5”说“aaaabbbbbccccc”。这是我到目前为止的代码
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
为什么我在 if 中的比较不起作用?答案应该是 8 但它返回 0。 function findMissing(missingArray){ var getArray = missing
我想知道为什么以下 JavaScript 比较会给出不同的结果。 (1==true==1) true (2==true==2) false (0==false==0) false (0==false)
我想知道是否有人可以帮助我完成这个程序。编写一个接受两个字符串的函数。该函数应该将这两个字符串与字典顺序上排在第一位的字符串组合起来。两个字符串之间应该有一个空格。在一行上打印结果字符串。在一行上打印
有谁知道一个免费的开源库(实用程序类),它允许您比较一个 Java bean 的两个实例并返回一个属性列表/数组,这两个实例的值不同?请发布一个小样本。 干杯 托马斯 最佳答案 BeanCompara
我是java新手。任何人都可以给出以下类声明的含义 public class ListNode, V> { K key; V value; ListNode next;
我需要用 C 语言计算和比较 3 种不同大小(100 * 100、1000 * 1000 和 10000 * 10000)的 2 个矩阵相乘的执行时间。我编写了以下简单代码来为 1000 * 1000
当我在 ACCESS 2007 中运行以下 SQL 时 Select Location, COUNT(ApartmentBuildings) AS TotalIBuildingsManaged Fro
根据我对互斥锁的了解——它们通常提供对共享资源的锁定功能。因此,如果一个新线程想要访问这个锁定的共享资源——它要么退出,要么必须不断轮询锁(并在等待锁时浪费处理器周期)。 但是,监视器具有条件变量,它
通常在编程中,不应该比较浮点数据类型是否相等,因为存储的值通常是近似值。 由于两个非整数 Oracle NUMBER 值的存储方式不同(以 10 为基数),是否可以可靠地比较它们是否相等? 最佳答案
使用 PowerShell 时,我们偶尔会比较不同类型的对象。一个常见的场景是 $int -eq $bool (即其中 0 -eq $false 、 0 -ne $true 和任何非零值仅等于真,但不
#include #define MAX 1000 void any(char s1[], char s2[], char s3[]); int main() { char string1[
我想比较两个日期。 从这两个日期中,我只使用 ToShortDateString() 获取日期组件, 如下所示。现在的问题是当我比较两个日期时。它的 throw 错误—— "Operator >= c
用户输入一个数字( float 或整数),并且它必须大于下限。 这是从 UITextField 获取数字的代码: NSNumberFormatter * f = [[NSNumberFormatter
我已经摆弄这段代码大约一个小时了,它让我难以置信。我认为解决方案相当简单,但我似乎无法弄清楚。无论如何,这里去。我制作了一个 javascript 函数来检查用户输入的字符,以便它只能接受 7 个字符
我不太明白为什么当我们在不覆盖 equals 的情况下比较具有相同类属性的两个实例时方法,它将给出 false .但它会给出 true当我们比较一个案例类的两个实例时。例如 class A(val
我是一名优秀的程序员,十分优秀!