C++指针/for 循环混淆
C++ pointer/for-loop confusion
我正在尝试编写一个程序,该程序使用指针从 cin 读取值,然后输出值及其在数组中的位置。我不知道为什么printNumbers1有效,但printNumbers2不起作用。这是程序(底部附近的相关代码):
#include <iostream>
using namespace std;
int *readNumbers(int);
void printNumbers1(int*);
void printNumbers2(int*);
int main()
{
int *numbers = readNumbers(5);
printNumbers1(numbers);
printNumbers2(numbers);
return 0;
}
int *readNumbers(int n)
{
int a[n];
int *numbers;
numbers = &a[0];
for (int i=0; i<n; i++)
{
cin >> *(numbers+i);
}
return numbers;
}
void printNumbers1(int *numbers)
{
cout << 0 << ' ' << *(numbers) << endl
<< 1 << ' ' << *(numbers+1) << endl
<< 2 << ' ' << *(numbers+2) << endl
<< 3 << ' ' << *(numbers+3) << endl
<< 4 << ' ' << *(numbers+4) << endl;
}
void printNumbers2(int *numbers)
{
for (int i=0; i<5; i++)
{
cout << i << ' ' << *(numbers+i) << endl;
}
}
当我运行该程序时,它按预期为 printNumbers1 工作,但为 printNumbers2 输出看似随机的数字和 0 的组合。我觉得两个 printNumbers 函数应该功能相同,但它们没有。我错过了什么?
发生这种情况是由于两件事的组合:
-
C++ 不允许可变长度数组- 这是一个流行的扩展,但声明
int a[n]
不是标准的。 -
您不能从函数返回指向局部变量的指针-
readNumbers
内部的指针numbers
指向局部变量a
一个局部变量。您可以在函数内部使用此指针,但在函数外部,它变得无效,因为a
超出范围。
使用超出范围的变量会导致未定义的行为。这个问答很好地解释了正在发生的事情,以及为什么它看起来程序运行良好。
如果要使用内置指针,请删除int a[n]
,并更改numbers
的声明,如下所示:
int *numbers = new int[n];
您还需要添加
delete[] numbers;
return 0
行之前,以避免内存泄漏。
我假设您编写此代码是作为学习练习的一部分。不过,一般来说,C++中更好的方法是使用std::vector<int>
,它从代码中隐藏指针操作,并为您处理资源管理。
readNumbers 返回指向具有自动存储持续时间的变量的指针。
取消引用该指针的行为是未定义的。
请改用 std::vector。依靠返回值优化来避免任何多余的价值副本。
在这里,您已经在函数内部创建了数组 a[n],因此它是一个局部变量,因此在函数范围结束后,可能会也可能不会删除此数组。切勿在函数之外使用局部变量的地址。此代码正在工作:
#include <iostream>
using namespace std;
int *readNumbers(int);
void printNumbers1(int*);
void printNumbers2(int*);
int main()
{
int *numbers = readNumbers(5);
printNumbers1(numbers);
printNumbers2(numbers);
return 0;
}
int *numbers;
int *readNumbers(int n)
{
numbers = new int[n];
for (int i=0; i<n; i++)
{
cin >> *(numbers+i);
}
return numbers;
}
void printNumbers1(int *numbers)
{
cout << 0 << ' ' << *(numbers) << endl
<< 1 << ' ' << *(numbers+1) << endl
<< 2 << ' ' << *(numbers+2) << endl
<< 3 << ' ' << *(numbers+3) << endl
<< 4 << ' ' << *(numbers+4) << endl;
}
void printNumbers2(int *numbers)
{
for (int i=0; i<5; i++)
{
cout << i << ' ' << *(numbers+i) << endl;
}
}
相关文章:
- 如何在C++中从两个单独的for循环中添加两个数组
- 为什么我的for循环不能正确获取argv
- 在基于范围的for循环中使用结构化绑定声明
- 通过for循环使用用户输入填充列表
- 使用for循环检查数组中的重复项
- 在for循环中使用auto vs decltype(vec.size())来处理字符串的向量
- 为什么 const std::p air<K,V>& 在 std::map 上基于范围的 for 循环不起作用?
- 正在使用for循环创建QScatterSerie
- Python中的for循环与C++有何不同
- 在更改for循环的第三部分后,未使用for循环结果
- 在 for 循环中查找问题时遇到困难
- 嵌套for循环C++的问题(初学者)
- 如何用for循环在c++中生成单词三角形
- 如何在for循环中包含两个索引值的测试条件
- 带有多个独立参数的C++For循环
- C++ Python 循环"for i, num in enumerate(list):"版本
- C 多循环 for () 基础知识
- 没有条件值的 FOR 循环"for (int i = 1; ; i++)"无法正常工作
- 为用户提供循环for循环的选项
- 打破循环for循环