如何在c++中重置所有变量

How to reset all variables in C++?

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

我的代码似乎没有任何问题,
但是我们的教授警告我们这个任务可能需要
重置变量,以便在第一次运行后干净地重新运行。

问题是我不知道如何重置变量和
我认为这对于更复杂的代码来说是必不可少的。帮助吗?

这个天气任务基本上是"询问用户现在是哪个月,
"然后询问最低温度,最高温度。,本月每天的雨量,
然后打印月平均值和总降雨量。

// Note to Stackoverflowers: Dager = days & Nedbor = rainfall.
// Other then that everything below is translated to english just for this
// question
#include <iostream>
#include <iomanip>
using namespace std;
int main() {
  char rerun = 'j';  // rerun program variable
  while (rerun == 'j' || rerun == 'J')  // rerun program
  {
    int antDager, antD;  // number of days
    int minTemp;
    float minTempAdd = 0;  // min.temp.
    int maxTemp;
    float maxTempAdd = minTempAdd;  // max.temp
    int mmNedbor;
    float mmNedborAdd = 0;  // rain/downfall
    do {
      cout << "ntHow many days in this month? (28 til 31)n";  //#days?
      cin >> antDager;
      if (31 < antDager || 28 > antDager)  // must be 28-31
      {
        cout << "ntInvalid valuen";
      }
    } while (31 < antDager || 28 > antDager);  // loop if invalid value
    for (antD = 1; antD < antDager;
         antD++,  // for loop the month
         minTempAdd += minTemp, maxTempAdd += maxTemp,
        mmNedborAdd +=
         mmNedbor) {  // the above increments temperatures and rain with itself
      do {
        cout << "ntminTemp? (-70 til 70), max.temp? (min til 70),   
            rain in mm
            ? (0 til 200)n ";      //sentence break for this website
                  cin >>
                  minTemp >> maxTemp >>
                  mmNedbor;  // temperatures and rain input
        if ((-70) > minTemp || 70 < minTemp) {
          cout << "ntInvalid min-valuen";
        }
        if (minTemp > maxTemp || 70 < maxTemp) {
          cout << "ntInvalid max-valuen";
        }
        if (0 > mmNedbor || 200 < mmNedbor) {
          cout << "ntInvalid Nedbor-valuen";
        }
      } while ((((-70) > minTemp || 70 < minTemp) ||
                (minTemp > maxTemp || 70 < maxTemp)) ||
               (0 > mmNedbor || 200 < mmNedbor));
    }
    cout << "ntGjennomsnittlig minTemp: " << minTempAdd / antDager;
    cout << "ntGjennomsnittlig minTemp: " << maxTempAdd / antDager;
    cout << "ntGjennomsnittlig nedbor: " << mmNedborAdd / antDager;
    cout << "ntTotal nedbor: " << mmNedborAdd << endl;
    cout << "ntØnsker du å kjøre programmet igjen? j/n";
    cin >> rep;
    if (rerun == 'n' || rerun == 'N') {
      cout << "ntExiting programn";
    }
  }
  return 0;
}

编辑:
我得到了一些关于缺乏初始化的反馈(我假设这意味着定义变量)。我试着不那么做。我的教授要求我们"尽可能多地使用const,尽量少地使用硬编码"变量。我在这里找不到const的任何用途,所以我用最小的"硬编码"来补偿,我希望他说的是初始化。

您的代码基本正确。这些变量将被删除并重新分配,因为它们位于内部作用域中。

你错在没有初始化它们。当你声明像int这样的原始类型时,你只会在堆栈上获得下一个4字节,因此它将包含那里的任何内容。

这通常是不好的,因为有时你假设它将是0。因此,要修复代码,只需确保显式初始化所有变量(为它们赋值0)。

由于c++的值语义,您已经为您重置了变量。在while循环中有

int antDager, antD;                                   //number of days    
int minTemp;  float minTempAdd = 0;               //min.temp.     
int maxTemp;  float maxTempAdd = minTempAdd;      //max.temp  
int mmNedbor; float mmNedborAdd = 0;  

当你到达while循环(})的末尾时,所有这些变量将超出作用域。然后,当你再次启动循环时,它们将被重新创建并重新设置为初始值。

你在你的for循环中使用mmNedbor, maxTempminTemp,在你初始化它们之前,这是未定义的行为,所以你应该将它们设置为一些默认的初始值。

这意味着在循环中使用的任何变量都应该在循环开始时初始化。

在你的例子中,你在循环中声明了所有相关的变量,但是你没有给它们赋一个初始值。如果您试图在写入这些未初始化的值之前读取它们,它们将包含未知数据。特别地,minTempmaxTempmmNedbor在没有初始化的情况下读取。所以要确保所有的变量都有初始值

只需在循环开始时将整个循环中使用的所有变量设置为0或其他值,就像您对minTempAdd和mmNedborAdd变量所做的那样。

作为旁注,您的代码很难阅读,因此我建议您花一些时间重构它。

ex: my name program is program_name.cpp
how to reset all variabel : 
my version is :
char choice;
cout<< "do you want to reset all variabel and loop the program"
cin>>choice;
if (choice=="y")system("program_name.axe")
else(exit(0))
if you want to reset ALL VARIABEL please dont use goto;