2013-06-27 52 views
0

所以基本上,错误:变量可能尚未初始化和if语句

//Black ops 2 Class generator Please help me FIX!!!!!! 
    import java.util.Scanner; 
    import java.util.Random; 
    public class money 
     { 
     public static void main(String[]args) 
      { 
     String primaryOption; 
     Scanner scan = new Scanner (System.in); 
     Random primaryGen = new Random(); 

     String weaponType; //Rifle, SMG, HMG, Sniper, shotgun, or special 
     String primaryoption; //Do you want a primary? 
     String primaryWeapon; //The gun you get 
     int primaryWeapon1; 
     String primrayCamo; //Camo for primary 
     String MTAR = "MTAR", Type25 = "Type 25", SWAT556 = "SWAT-556", FALOSW = "FAL-OSW", M27 = "M27", SCARH = "SCAR-H", SMR = "SMR", M8A1 = "M8A1", AN94 = "AN-94"; 

     String secondaryOption; //Do you want a secondary? 
     String secondaryWeapon; //Your gun 
     int secondaryWeapon1; 
     String secondaryCamo; //Camo for secondary 
     System.out.println("Would you like a Primary Weapon? Yes(1) or No(2)"); 
     primaryOption = scan.nextLine(); 
      if (primaryOption.equals("Yes")) { 
       System.out.println("Would you like a Rifle, SMG, HMG, Sniper, Shotgun, or Special?)"); 
       weaponType = scan.nextLine(); 
        if (weaponType.equals("Rifle")) { 
         primaryWeapon1 = primaryGen.nextInt(1) +1; 
         if (primaryWeapon1 == 1) { 
          primaryWeapon = MTAR; //*&%&*This is where i initialized it. 
    } 
       return; 

          } 
    System.out.println("Primary Weapon: " + primaryWeapon); //This is where the error is. It say's im not initializing the variable but I initialize it in the last if statement 
    } 
    } 
    } 
+0

'字符串primaryWeapon = “徒手”;' – jxh

回答

1

It say's im not initializing the variable but I initialize it in the last if statement

如果说“如果”不执行块会发生什么?那么这个变量将被分配正确吗?这就是编译器抱怨的原因。

应该在所有可能的流程中分配局部变量,否则就是编译时错误。

1

您必须在使用它之前初始化变量。如果if语句失败,这个变量将保持未初始化:

System.out.println("Primary Weapon: " + primaryWeapon); 

所以,在这里你声明它,等于它""

String primaryWeapon = ""; //The gun you get 
0

在有些情况下PrimaryWeapon从未初始化的情况下(只要PrimaryWeapon1不等于1)。

使用此,它的固定:

String primaryWeapon = ""; 
0

我觉得你的问题就出在这个if语句: 假设你在这里和weaponType不等于“步枪”,它将返回并退出功能。你应该初始化你的primaryWeapon为默认值,即primaryWeapon =“None”;

if (weaponType.equals("Rifle")) { 
         primaryWeapon1 = primaryGen.nextInt(1) +1; 
         if (primaryWeapon1 == 1) { 
          primaryWeapon = MTAR; //*&%&*This is where i initialized it. 
         } 
         return; //<---- remove this 
} 

而且完成,如果块,if(yes) {...} else {...}. Java编译器会另辟蹊径条件子句,并尝试使用unintialized变量时会发出警告/错误。例如:

int b; 
boolean f = true; 
if(f) 
    b =1; 
System.out.println(b); //error because no else block 


//Fixed 
int b; 
boolean f = true; 
if(f) 
b = 1; 
else 
b= 2; 
System.out.println(b); 

--Niru