- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我一直在学习 C 语言并遵循 Yashavant P. Kanetkar 的“Let Us C”。
指针章节中有一行说我们只能比较即小于 (<) 和大于 (>) 指向同一数组中元素的指针。
为什么比较任意指针无效?
最佳答案
因为 C 不假设主机,也没有什么能阻止主机在两个完全独立的地址空间中分配两个数组。
It's not just about theoretical exotic architectures either . x86 机器的 16 位编译器提供了两种指针。近指针有 16 位宽并且表现得像你期望的那样;但是,它们只允许您访问 64k 的 RAM。如果您想访问超过 64k 的 RAM(不是每个 block 64K:整个程序 64K!),您必须使用远指针。
远指针为 32 位宽,由两个 16 位的一半组成,即 段
和 偏移量
;例如 1234:0000
是一个指针,它有段 0x1234
和偏移量 0。实际内存地址是 段 * 16 + 偏移量
。通常,farmalloc
返回一个偏移量为零的指针,指针运算仅修改偏移量。所以你可以有
char *x = farmalloc(64); // returns 1234:0000 for address 0x12340
char *y = farmalloc(64); // returns 1238:0000 for address 0x12380
现在,如果您计算 x + 128
,结果是 1234:0080
,地址为 0x123C0。它比较小于
1238:0000(因为 0x1234 < 0x1238)但它指向更高的地址(因为 0x123C0 > 0x1238)。
为什么?因为将 128 加到指向 64 字节对象的 x
是未定义的行为。
memory model编译器设置定义了指针的默认大小是 near 还是 far。例如,“小”内存模型有 64K 用于代码,64K 用于所有全局变量、自动变量(堆栈)和 malloc 堆。请注意,代码位于单独的段中,因此您不能只使用 16 位(“近”)函数指针并取消引用它来读取机器语言!如果您必须这样做,则必须要求编译器将代码与其余代码放在同一段中(“微型”内存模型)。
某些内存模型让编译器始终使用远指针,如果数据+堆栈+堆超过 64K(“紧凑”或“大”内存模型),这会更慢但有必要。
代码和数据的大小也不同,所以你可以有一个内存模型,其中函数指针很近而数据指针很远,反之亦然。上述“紧凑”模型(64K 代码限制,但数据远指针)和双“中等”模型(代码远指针,64K 数据限制)就是这种情况。
还有一种方法可以让编译器对所有内容使用平面 32 位指针(所谓的“巨大”内存模型),但是速度很慢而且没有人使用它。
关于c - 为什么我们不能比较不指向同一数组中元素的指针?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31914652/
我刚接触 C 语言几周,所以对它还很陌生。 我见过这样的事情 * (variable-name) = -* (variable-name) 在讲义中,但它到底会做什么?它会否定所指向的值吗? 最佳答案
我有一个指向内存地址的void 指针。然后,我做 int 指针 = void 指针 float 指针 = void 指针 然后,取消引用它们以获取值。 { int x = 25; vo
我正在与计算机控制的泵进行一些串行端口通信,我用来通信的 createfile 函数需要将 com 端口名称解析为 wchar_t 指针。 我也在使用 QT 创建一个表单并获取 com 端口名称作为
#include "stdio.h" #include "malloc.h" int main() { char*x=(char*)malloc(1024); *(x+2)=3; --
#include #include main() { int an_int; void *void_pointer = &an_int; double *double_ptr = void
对于每个时间步长,我都有一个二维矩阵 a[ix][iz],ix 从 0 到 nx-1 和 iz 从 0 到 nz-1。 为了组装所有时间步长的矩阵,我定义了一个长度为 nx*nz*nt 的 3D 指针
我有一个函数,它接受一个指向 char ** 的指针并用字符串填充它(我猜是一个字符串数组)。 *list_of_strings* 在函数内部分配内存。 char * *list_of_strings
我试图了解当涉及到字符和字符串时,内存分配是如何工作的。 我知道声明的数组的名称就像指向数组第一个元素的指针,但该数组将驻留在内存的堆栈中。 另一方面,当我们想要使用内存堆时,我们使用 malloc,
我有一个 C 语言的 .DLL 文件。该 DLL 中所有函数所需的主要结构具有以下形式。 typedef struct { char *snsAccessID; char *
指针, C语言的精髓 莫队先咕几天, 容我先讲完树剖 (因为后面树上的东西好多都要用树剖求 LCA). 什么是指针 保存变量地址的变量叫做指针. 这是大概的定义, 但是Defad认为
我得到了以下数组: let arr = [ { children: [ { children: [], current: tru
#include int main(void) { int i; int *ptr = (int *) malloc(5 * sizeof(int)); for (i=0;
我正在编写一个程序,它接受一个三位数整数并将其分成两个整数。 224 将变为 220 和 4。 114 将变为 110 和 4。 基本上,您可以使用模数来完成。我写了我认为应该工作的东西,编译器一直说
好吧,我对 C++ 很陌生,我确定这个问题已经在某个地方得到了回答,而且也很简单,但我似乎找不到答案.... 我有一个自定义数组类,我将其用作练习来尝试了解其工作原理,其定义如下: 标题: class
1) this 指针与其他指针有何不同?据我了解,指针指向堆中的内存。如果有指向它们的指针,这是否意味着对象总是在堆中构造? 2)我们可以在 move 构造函数或 move 赋值中窃取this指针吗?
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: C : pointer to struct in the struct definition 在我的初学者类
我有两个指向指针的结构指针 typedef struct Square { ... ... }Square; Square **s1; //Representing 2D array of say,
变量在内存中是如何定位的?我有这个代码 int w=1; int x=1; int y=1; int z=1; int main(int argc, char** argv) { printf
#include #include main() { char *q[]={"black","white","red"}; printf("%s",*q+3); getch()
我在“C”类中有以下函数 class C { template void Func1(int x); template void Func2(int x); }; template void
我是一名优秀的程序员,十分优秀!