在c++中使用for循环时,具有相同名称的变量

Variables with the same name when using for loop in C++

本文关键字:变量 c++ for 循环      更新时间:2023-10-16

考虑以下代码片段:

unsigned int i;
double* u = new double [10];
for (i=0; i<10; i++)
{
    double u = 5.0;
    // Other code
}
delete[] u;

是否可以使用变量名u两次?或者这是不受欢迎的?使用某些编译器,代码会编译失败吗?

编辑:这样更好吗?或者它仍然会让未来的代码维护者感到困惑吗?
unsigned int i;
double* u = new double [10];
// Do stuff with u
delete[] u;
for (i=0; i<10; i++)
{
    double u = 5.0;
    // Other code
}

代码

double u = 5.0;
循环内的

将遮蔽定义

double* u = new double [10];

在它之前制作。
循环中的所有代码只看到double u。它的目的是编译得很好,除了给未来的代码维护者带来混乱之外,从语法的角度来看,没有任何问题。


注意:
如果不在循环中使用double* u,那么在它之前定义这个变量是没有意义的。根据经验:

局部变量定义应该出现在它们的第一个使用点之前。


关于你编辑过的问题:
是的,这将更清楚,在某种意义上,人们可以看到意图double* u;不应该在delete[] u;之后使用。虽然它既不安全,而且仍然令人困惑,如果一个人没有立即发现循环内的double u;的阴影定义。

为了不让任何人感到困惑,IMHO总体上更好的解决方案是将循环中的代码或处理double* u的代码分解为单独的函数,或者甚至只是使用不同的变量名称。

这将适用于大多数编译器。然而,这通常不是一个好的实践,因为它可能导致程序员的困惑,特别是当程序变得很大时。