C++ 比较指针对象相等性
在处理C(有时是C++)中的指针时,我遇到了一个有趣的例子:假设我们有一个结构(C结构),如下所示:C++ 比较指针对象相等性,c++,c,pointers,reference,C++,C,Pointers,Reference,在处理C(有时是C++)中的指针时,我遇到了一个有趣的例子:假设我们有一个结构(C结构),如下所示: struct qwe { int someData; qwe *ptr; } if (p == p->ptr) printf("True\n"); 然后是一些代码: struct qwe d, *p = &d; p->someData = 1; p->ptr = p; 我知道这些指针指向同一个对象,并且基于语言规范中==的定义,使用此运算符
struct qwe
{
int someData;
qwe *ptr;
}
if (p == p->ptr)
printf("True\n");
然后是一些代码:
struct qwe d, *p = &d;
p->someData = 1;
p->ptr = p;
我知道这些指针指向同一个对象,并且基于语言规范中==
的定义,使用此运算符如下:
struct qwe
{
int someData;
qwe *ptr;
}
if (p == p->ptr)
printf("True\n");
现在,这一切都没问题,但这两个指针根本不是同一个对象。这里的问题是关于是否有一种检查指针相等的方法。现在,我知道我可以做一些事情,比如创建一个指向这些指针的指针,然后将这些新指针与==
进行比较,如下所示
struct qwe** pToPtr_1 = &p;
struct qwe** pToPtr_2 = &(p->ptr);
if (pToPtr_1 == pToPtr_2)
printf("True\n");
,这将不会向控制台生成输出,但我想知道是否有一种方法可以直接比较指针地址。我知道这有点无用(至少基于我目前对C编程语言的理解和需求),但我仍然想知道C(或C++)中是否存在这样的功能。任何变量都可以通过其地址进行唯一标识 通过将地址运算符
和应用于变量来计算地址
因此,您的示例比较了这些值
p == p->ptr
然后看起来像
&p == &p->ptr
比较指针实例的相等性
注意:这种方法不仅限于指针,而且可以应用于任何数据类型的变量。tl;医生:没有更“直接”的方法了;您已经使用该语言提供的工具正确比较了两个指针的标识。
你所问的与其说是平等,不如说是身份。您希望看到两个对象实际上是同一个对象,占用内存空间,这与具有相同值的两个独立对象不同
如前所述,您可以通过比较指向两个对象的指针来检查它们的标识。你在比较地址。当地址相同时,它实际上只是一个对象
同样的方法也适用于指针,指针本身就是对象。您已经在回答中编写了相应的代码:
struct qwe** pToPtr_1 = &p;
struct qwe** pToPtr_2 = &(p->ptr);
if (pToPtr_1 == pToPtr_2)
printf("True\n");
您可以通过避免声明来缩短它:
if (&p == &p->ptr)
printf("True\n");
结构声明不是有效的c代码,除非您有以前的typedeftypedef struct qwe qwe代码>。什么是但是这两个指针根本不是相同的对象
应该是什么意思?我忘了提到已经完成了。谢谢您的更正。@iharob它们确实指向同一个对象,但它们本身不是同一个对象。您想测试标识。要做到这一点,最简单的方法是像您所做的那样,获取对象的地址<代码>&p==&(p->ptr)
。不管你是不是在处理指针,都是无关紧要的。你只是用不同的话告诉了我所说的:/如果两个指针有相同的值,它们指向内存中的同一个对象(也称为相同的内存地址),正如我上面提到的。