Java ArrayList of Arrays?

后端 未结 7 837
情书的邮戳
情书的邮戳 2020-12-05 01:43

I want to create a mutli dimensional array without a fixed size.

I need to be able to add items of String[2] to it.

I have tried looking at:

相关标签:
7条回答
  • 2020-12-05 02:20
    1. Create the ArrayList like ArrayList action.

      In JDK 1.5 or higher use ArrayList <string[]> reference name.

      In JDK 1.4 or lower use ArrayList reference name.

    2. Specify the access specifiers:

      • public, can be accessed anywhere
      • private, accessed within the class
      • protected, accessed within the class and different package subclasses
    3. Then specify the reference it will be assigned in

      action = new ArrayList<String[]>();
      
    4. In JVM new keyword will allocate memory in runtime for the object.

      You should not assigned the value where declared, because you are asking without fixed size.

    5. Finally you can be use the add() method in ArrayList. Use like

      action.add(new string[how much you need])
      

      It will allocate the specific memory area in heap.

    0 讨论(0)
  • 2020-12-05 02:26
    ArrayList<String[]> action = new ArrayList<String[]>();
    

    Don't need String[2];

    0 讨论(0)
  • 2020-12-05 02:28

    This works very well.

    ArrayList<String[]> a = new ArrayList<String[]>();
        a.add(new String[3]);
        a.get(0)[0] = "Zubair";
        a.get(0)[1] = "Borkala";
        a.get(0)[2] = "Kerala";
    System.out.println(a.get(0)[1]);
    

    Result will be

    Borkala
    
    0 讨论(0)
  • 2020-12-05 02:30

    Since the size of your string array is fixed at compile time, you'd be better off using a structure (like Pair) that mandates exactly two fields, and thus avoid the runtime errors possible with the array approach.

    Code:

    Since Java doesn't supply a Pair class, you'll need to define your own.

    class Pair<A, B> {
      public final A first;
      public final B second;
    
      public Pair(final A first, final B second) {
        this.first = first;
        this.second = second;
      }
    
      //
      // Override 'equals', 'hashcode' and 'toString'
      //
    }
    

    and then use it as:

    List<Pair<String, String>> action = new ArrayList<Pair<String, String>>();
    

    [ Here I used List because it's considered a good practice to program to interfaces. ]

    0 讨论(0)
  • 2020-12-05 02:31

    BTW. you should prefer coding against an Interface.

    private ArrayList<String[]> action = new ArrayList<String[]>();
    

    Should be

    private List<String[]> action = new ArrayList<String[]>();
    
    0 讨论(0)
  • 2020-12-05 02:36

    Should be

    private ArrayList<String[]> action = new ArrayList<String[]>();
    action.add(new String[2]);
    ...
    

    You can't specify the size of the array within the generic parameter, only add arrays of specific size to the list later. This also means that the compiler can't guarantee that all sub-arrays be of the same size, it must be ensured by you.

    A better solution might be to encapsulate this within a class, where you can ensure the uniform size of the arrays as a type invariant.

    0 讨论(0)
提交回复
热议问题