在循环中显示不同值的初始化数组
Initialised arrays showing different values in a loop
我初始化了一个数组并尝试使用循环和递归显示元素,但每次它显示的值都与原始值不同。 我尝试单独显示元素,它工作正常。
这是定义数组的类定义:
class stack
{
public:
int top, *arr;
stack(int s)
{
top=-1;
size=s;
arr=def_arr(s);
}
void push(int num)
{
if(top>=size-1)
{
cout<<"Stack has reached maximum length";
}
else
{
top++;
arr[top]=num;
}
}
int pop()
{
if(top>-1)
{
int temp;
temp=arr[top];
top--;
return temp;
}
else
{
cout<<"The stack has no values";
}
}
void print()
{
if(top>-1)
{
for(int i=0; i<=top; i++)
{
cout<<arr[i];
cout<<"t";
}
}
else
{
cout<<"Can't print stack of length 0";
}
}
private:
int size;
int *def_arr(int size)
{
int arr[size];
return arr;
}
};
还有我运行的代码:
int main()
{
stack A(3);
A.push(5);
A.push(8);
A.push(10);
cout<<A.arr[1]<<"n";
A.print();
}
结果是:
8
5 87 -1259567440
我错过了什么?
int *def_arr(int size)
{
int arr[size];
return arr;
}
是错误的,因为它返回指向局部变量arr
的指针。一旦函数退出,局部变量就不再存在,因此指针指向无效地址(也称为悬空指针(。使用该指针是未定义的行为。
可变长度数组 (VLA( 是 C++ 中的非标准构造。
两种可能的解决方案
1( 使用 std::vector
#include <vector>
std::vector<int> def_arr(int size)
{
std::vector<int> arr(size);
return arr;
}
这将需要在代码中的其他地方进行更改(主要是类中的arr
也必须重新声明为 std::vector(。
2( 使用动态内存分配
int *def_arr(int size)
{
int* arr = new int[size];
return arr;
}
这将导致代码中的内存泄漏,修复这些并非易事,您应该阅读"三法则"。
大多数人会推荐选项 1。恭喜您即将了解C++中最重要的主题,即资源管理。
相关文章:
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 在函数内部的声明中初始化数组,并在外部使用它
- 为什么用结构初始化数组需要指定结构名称
- 有没有一种代码密度较低的方法来使用非默认构造函数初始化数组?
- C++使用另一个数组和新值初始化数组
- 初始化数组、"memset"或" {//value} "的最佳方法是什么?
- 在 constexpr 构造函数中初始化数组是否合法?
- 我可以初始化 const 实例,以便我可以将其用作 const 来初始化数组吗?
- 在构造函数中初始化数组
- 是否可以使用函数返回的值初始化数组
- 使用宏使用额外元素初始化数组
- 在循环中显示不同值的初始化数组
- 如何在macOS中的旧扩展clang和gcc编译器中初始化数组和向量
- 使用可变模板列表初始化数组,并放置new
- 使用函数从 Visual Studio 2017 中的 main 创建和初始化数组
- 使用 c++ 中的函数初始化数组
- 这是使用构造函数初始化数组对象的最佳方法吗?
- C++ 使用变量而不是常量表达式初始化数组
- 在初始化列表中初始化数组的更好方法
- 在可变参数模板类中初始化数组