2016-09-11 9 views
1

だから、IPv4の文字列がこの文字列が配列に作用しないのはなぜですか?

public static boolean isValidElement(String token) { 
    String[] validString = token.split("\\."); 
    if (validString.length != 4) 
     return false; 
    for (String str: validString) { 
     try{     
      int i = Integer.parseInt(str); 
      if ((i < 0) || (i > 255)) { 
       return false; 
      } 
     } 
     catch(NumberFormatException ex){ 
      return false; 
     } 
    } 
    return true; 
} 

をisValidElementに渡され、罰金とダンディすべてのthatsが、その文字列を配列に文字列を格納するためのメソッドに渡されたとき、それは仕事をdoenstています。

public void setParts(String ip) { 
    parts = new int[4]; 
    if (!isValidElement(ip)) 
     for(int i = 0; i <= parts.length; i++) 
      parts[i] = 0; 
    else 
     try { 
      String[] ipArr = ip.split("\\."); 
      for (int i = 0; i < ipArr.length; i++) { 
       parts[i] = Integer.parseInt(ipArr[i]); 
      } 
     } 
     catch (NumberFormatException e) { 
      parts = new int[4]; 
     } 
} 

どこが間違っていますか?私は何が欠けていますか?

私はJUnitテスト

public void testSetPartsString() { 
    correct1.setParts("12.14.16.18"); 
    int[] a = correct1.getParts(); 
    assertEquals(4, a.length); 
    assertEquals(12, a[0]); 
    assertEquals(14, a[1]); 
    assertEquals(16, a[2]); 
    assertEquals(18, a[3]); 

を持っている。しかし、それは

assertEquals(4, a.length); 

で動作を停止し、私は適切にインスタンスアレイ部分をリセットしないことがありますか?

+1

[MCVE]を投稿してください。 – c0der

+0

ブレークポイントを設定し、デバッグモードでコードを見てみませんか? –

+0

@TimmyJim私はsetPartsを使ってブレークポイントを設定しましたが、それは私のために働いていません –

答えて

0

次のコードはうまくいきます。

public class AssertionCheck { 

public static void main(String[] args) { 
    String ip="12.14.16.18"; 
    int[] parts = new int[4]; 
      if(!(isValidElement(ip))) 
       for(int i = 0; i<=parts.length; i++) 
        parts[i] = 0; 
      else{ 
        String[] ipArr = ip.split("\\."); 
        Assert.assertEquals(4, ipArr.length); 
        Assert.assertEquals(12, Integer.parseInt(ipArr[0])); 
        Assert.assertEquals(14, Integer.parseInt(ipArr[1])); 
        Assert.assertEquals(16, Integer.parseInt(ipArr[2])); 
        Assert.assertEquals(18, Integer.parseInt(ipArr[3])); 
        System.out.println("Assertion completed Successfully"); 
      } 
      } 

public static boolean isValidElement(String token) { 
    String[] validString = token.split("\\."); 
    if (validString.length != 4) 
     return false; 
    for (String str: validString) { 
     try{     
      int i = Integer.parseInt(str); 
      if ((i < 0) || (i > 255)) { 
       return false; 
      } 
     } 
     catch(NumberFormatException ex){ 
      return false; 
     } 
    } 
    return true; 
} 

}

関連する問題