/Zc:forScope(强制 for 循环范围中的一致性)
用于实现标准 C++ 行为用于 for 循环,其具有 Microsoft 扩展 (/Ze)。 默认情况下,/Zc:forScope 处于打开状态。
/Zc:forScope[-]
备注
标准行为是使 for 循环的初始值设定项在 for 循环之后超出范围。 在 /Za、/Ze(禁用语言扩展) 下,for 循环的初始值设定项保持在范围内,直到局部范围结束。
下面的代码将在 /Ze(而不是 /Za)下进行编译:
// zc_forScope.cpp
// compile with: /Zc:forScope- /Za
// C2065 expected
int main() {
// Uncomment the following line to resolve.
// int i;
for (int i =0; i < 1; i++)
;
i = 20; // i has already gone out of scope under /Za
}
在您使用 /Zc:forScope- 时,如果变量因为存在一个在以前的范围内所做的声明而处在范围内,您将得到警告(默认情况下处于关闭状态)。 为了说明这点,请移除上面代码中的 // 字符以声明 int i。
可以使用 conform 杂注修改 /Zc:forScope 的运行时行为。
如果在具有现有 .pch 文件的项目中使用 /Zc:forScope-,则忽略 /Zc:forScope-(伴有警告),并继续用现有的 .pch 文件进行编译。 如果需要生成新的 .pch 文件,请使用 /Yc(创建预编译的头文件)。
有关使用 Visual C++ 时的一致性问题的更多信息,请参见 兼容性和标准在Visual C++问题。
在 Visual Studio 开发环境中设置此编译器选项
打开项目的**“属性页”**对话框。 有关详细信息,请参见修改项目设置。
单击**“C/C++”**文件夹。
单击**“语言”**属性页。
修改**“强制 For 循环范围中的一致性”**属性。