有人可以向我解释一下为什么以下代码的输出显示数组不相等?
int main()
{
int iar1[] = {1, 2, 3, 4, 5};
int iar2[] = {1, 2, 3, 4, 5};
if (iar1 == iar2)
cout << "Arrays are equal.";
else
cout << "Arrays are not equal.";
}
if (iar1 == iar2)
这里
iar1
和 iar2
是 decaying ,指向各自数组的第一个元素。由于它们是两个不同的数组,因此指针值当然不同,并且您的比较测试不相等。
std::array
代替
std::array<int, 5> iar1 {1,2,3,4,5};
std::array<int, 5> iar2 {1,2,3,4,5};
if( iar1 == iar2 ) {
// arrays contents are the same
} else {
// not the same
}
由于还没有人提到它,您可以将数组与
std::equal
算法进行比较:
int iar1[] = {1,2,3,4,5};
int iar2[] = {1,2,3,4,5};
if (std::equal(std::begin(iar1), std::end(iar1), std::begin(iar2)))
cout << "Arrays are equal.";
else
cout << "Arrays are not equal.";
您需要包括
<algorithm>
和 <iterator>
。如果你还没有使用C++11,你可以这样写:
if (std::equal(iar1, iar1 + sizeof iar1 / sizeof *iar1, iar2))
您不是在比较数组的内容,而是在比较数组的地址。由于它们是两个独立的数组,因此它们具有不同的地址。
通过使用更高级别的容器来避免此问题,例如
std::vector
、std::deque
或 std::array
。
数组不是原始类型,并且数组在 C++ 内存中属于不同的地址。
没人提到
memcmp
?这也是一个不错的选择。
/* memcmp example */
#include <stdio.h>
#include <string.h>
int main ()
{
char buffer1[] = "DWgaOtP12df0";
char buffer2[] = "DWGAOTP12DF0";
int n;
n=memcmp ( buffer1, buffer2, sizeof(buffer1) );
if (n>0) printf ("'%s' is greater than '%s'.\n",buffer1,buffer2);
else if (n<0) printf ("'%s' is less than '%s'.\n",buffer1,buffer2);
else printf ("'%s' is the same as '%s'.\n",buffer1,buffer2);
return 0;
}
如果您不愿意将现有代码更改为
std::array
,请使用几种方法,这些方法采用非类型模板参数:
//Passed arrays store different data types
template <typename T, typename U, int size1, int size2>
bool equal(T (&arr1)[size1], U (&arr2)[size2] ){
return false;
}
//Passed arrays store SAME data types
template <typename T, int size1, int size2>
bool equal(T (&arr1)[size1], T (&arr2)[size2] ){
if(size1 == size2) {
for(int i = 0 ; i < size1; ++i){
if(arr1[i] != arr2[i]) return false;
}
return true;
}
return false;
}
这是演示。请注意,在调用时,我们只需要传递数组变量,例如
equal(iar1, iar2)
在你的情况下,不需要传递数组的大小。
您正在比较地址而不是值。
两者都将内存地址存储到两个不同数组的第一个元素。这些地址不能相等,因此输出。
如果您愿意使用
std::array
代替内置数组,您可以使用:
std::array<int, 5> iar1 = {1,2,3,4,5};
std::array<int, 5> iar2 = {1,2,3,4,5};
if (iar1 == iar2)
对。在most中,如果不是所有C实现,数组标识符可以隐式转换为指向第一个元素的指针(即第一个元素的地址)。您在这里所做的是比较这些地址,这显然是错误的。
相反,您需要迭代两个数组,相互检查每个元素。如果你没有失败就完成了两者,那么它们是平等的。
当我们使用数组时,我们实际上使用的是指向数组中第一个元素的指针。因此,这个条件
if( iar1 == iar2 )
实际上是比较两个地址。这些指针不指向同一个对象。