답변:
배열의 크기는 수정할 수 없습니다. 더 큰 배열을 원하면 새 배열을 인스턴스화해야합니다.
더 나은 해결책은 ArrayList
필요에 따라 성장할 수 있는 것을 사용하는 것입니다. 이 방법으로 ArrayList.toArray( T[] a )
배열이 필요한 경우이 메소드를 사용하여 배열을 반환합니다.
List<String> where = new ArrayList<String>();
where.add( ContactsContract.Contacts.HAS_PHONE_NUMBER+"=1" );
where.add( ContactsContract.Contacts.IN_VISIBLE_GROUP+"=1" );
간단한 배열로 변환 해야하는 경우 ...
String[] simpleArray = new String[ where.size() ];
where.toArray( simpleArray );
그러나 배열로 수행하는 대부분의 작업은이 ArrayList로 수행 할 수 있습니다.
// iterate over the array
for( String oneItem : where ) {
...
}
// get specific items
where.get( 1 );
List<String>
와 같은을 사용하십시오 ArrayList<String>
. 배열과 달리 동적으로 확장 가능합니다 ( 유효한 Java 2 판, 항목 25 : 배열 목록 선호 ).
import java.util.*;
//....
List<String> list = new ArrayList<String>();
list.add("1");
list.add("2");
list.add("3");
System.out.println(list); // prints "[1, 2, 3]"
배열 사용을 고집하는 경우 java.util.Arrays.copyOf
추가 요소를 수용하기 위해 더 큰 배열을 할당하는 데 사용할 수 있습니다 . 그러나 이것이 실제로 최상의 솔루션은 아닙니다.
static <T> T[] append(T[] arr, T element) {
final int N = arr.length;
arr = Arrays.copyOf(arr, N + 1);
arr[N] = element;
return arr;
}
String[] arr = { "1", "2", "3" };
System.out.println(Arrays.toString(arr)); // prints "[1, 2, 3]"
arr = append(arr, "4");
System.out.println(Arrays.toString(arr)); // prints "[1, 2, 3, 4]"
이것은 O(N)
당 append
입니다. ArrayList
반면에 O(1)
작업 당 비용 이 상각되었습니다.
ArrayList
내부적으로 무엇을 하는가 .
Apache Commons Lang은
T[] t = ArrayUtils.add( initialArray, newitem );
새로운 배열을 반환하지만 어떤 이유로 든 배열로 작업하는 경우 이것이 이상적인 방법 일 수 있습니다.
여기에 보지 않았고 "복잡한"객체 또는 컬렉션과 관련되지 않은 다른 옵션이 있습니다.
String[] array1 = new String[]{"one", "two"};
String[] array2 = new String[]{"three"};
String[] array = new String[array1.length + array2.length];
System.arraycopy(array1, 0, array, 0, array1.length);
System.arraycopy(array2, 0, array, array1.length, array2.length);
append()
배열 에는 메소드가 없습니다 . 대신 이미 제안한 것처럼 List 객체는 요소를 동적으로 삽입해야 할 필요성을 처리 할 수 있습니다.
List<String> where = new ArrayList<String>();
where.add(ContactsContract.Contacts.HAS_PHONE_NUMBER + "=1");
where.add(ContactsContract.Contacts.IN_VISIBLE_GROUP + "=1");
또는 실제로 배열을 사용하려는 경우 :
String[] where = new String[]{
ContactsContract.Contacts.HAS_PHONE_NUMBER + "=1",
ContactsContract.Contacts.IN_VISIBLE_GROUP + "=1"
};
그러나 이것은 고정 크기이며 요소를 추가 할 수 없습니다.
이와 같은 간단한 배열로 데이터를 저장하려면
String[] where = new String[10];
그리고 숫자처럼 몇 가지 요소를 추가하고 싶습니다. 문자열을 연결하는 것보다 훨씬 효율적인 StringBuilder.
StringBuilder phoneNumber = new StringBuilder();
phoneNumber.append("1");
phoneNumber.append("2");
where[0] = phoneNumber.toString();
이것은 문자열을 작성하고 'where'배열에 저장하는 훨씬 좋은 방법입니다.
문자열 배열에 새 항목을 추가합니다.
String[] myArray = new String[] {"x", "y"};
// Convert array to list
List<String> listFromArray = Arrays.asList(myArray);
// Create new list, because, List to Array always returns a fixed-size list backed by the specified array.
List<String> tempList = new ArrayList<String>(listFromArray);
tempList.add("z");
//Convert list back to array
String[] tempArray = new String[tempList.size()];
myArray = tempList.toArray(tempArray);
<code>
태그 를 사용 했고 이것은 일반적인 유형에 문제가있었습니다. 문제가 있기 때문에이 태그를 사용하지 말고 올바른 형식을 얻으려면 4 개의 공백이있는 코드를 들여 쓰기하십시오. 나는 당신의 질문에 대해 그렇게했습니다 :).
배열에 요소를 추가하는 방법에는 여러 가지가 있습니다. temp List
를 사용하여 요소를 관리 한 다음 다시 변환 Array
하거나 java.util.Arrays.copyOf
더 나은 결과를 위해 요소 를 사용하여 제네릭과 결합 할 수 있습니다 .
이 예제는 다음과 같은 방법을 보여줍니다.
public static <T> T[] append2Array(T[] elements, T element)
{
T[] newArray = Arrays.copyOf(elements, elements.length + 1);
newArray[elements.length] = element;
return newArray;
}
이 방법을 사용하려면 다음과 같이 호출하면됩니다.
String[] numbers = new String[]{"one", "two", "three"};
System.out.println(Arrays.toString(numbers));
numbers = append2Array(numbers, "four");
System.out.println(Arrays.toString(numbers));
두 배열을 병합하려면 다음과 같이 이전 방법을 수정할 수 있습니다.
public static <T> T[] append2Array(T[] elements, T[] newElements)
{
T[] newArray = Arrays.copyOf(elements, elements.length + newElements.length);
System.arraycopy(newElements, 0, newArray, elements.length, newElements.length);
return newArray;
}
이제 다음과 같이 메소드를 호출 할 수 있습니다.
String[] numbers = new String[]{"one", "two", "three"};
String[] moreNumbers = new String[]{"four", "five", "six"};
System.out.println(Arrays.toString(numbers));
numbers = append2Array(numbers, moreNumbers);
System.out.println(Arrays.toString(numbers));
앞서 언급했듯이 List
객체를 사용할 수도 있습니다 . 그러나 다음과 같이 안전하게 캐스팅하려면 약간의 해킹이 필요합니다.
public static <T> T[] append2Array(Class<T[]> clazz, List<T> elements, T element)
{
elements.add(element);
return clazz.cast(elements.toArray());
}
이제 다음과 같이 메소드를 호출 할 수 있습니다.
String[] numbers = new String[]{"one", "two", "three"};
System.out.println(Arrays.toString(numbers));
numbers = append2Array(String[].class, Arrays.asList(numbers), "four");
System.out.println(Arrays.toString(numbers));
newArray[elements.length] = element;
, 당신은 의미 newArray[elements.length - 1] = element;
했습니까?
실제로 배열의 크기를 조정하려면 다음과 같이 할 수 있습니다.
String[] arr = {"a", "b", "c"};
System.out.println(Arrays.toString(arr));
// Output is: [a, b, c]
arr = Arrays.copyOf(arr, 10); // new size will be 10 elements
arr[3] = "d";
arr[4] = "e";
arr[5] = "f";
System.out.println(Arrays.toString(arr));
// Output is: [a, b, c, d, e, f, null, null, null, null]
충분히 큰 메모리 크기를 미리 할당 할 수도 있습니다. 다음은 간단한 스택 구현입니다. 프로그램은 3과 5를 출력해야합니다.
class Stk {
static public final int STKSIZ = 256;
public int[] info = new int[STKSIZ];
public int sp = 0; // stack pointer
public void push(int value) {
info[sp++] = value;
}
}
class App {
public static void main(String[] args) {
Stk stk = new Stk();
stk.push(3);
stk.push(5);
System.out.println(stk.info[0]);
System.out.println(stk.info[1]);
}
}