2016-09-21 2 views
0

ArrayBasedStack 메서드 중 하나 인 toArray 메서드에 대한 junit 테스트를 작성하고 있습니다. 이 클래스는 내부에 배열을 가지고 있으며 toArray 메서드는 요소를 복사하고 반환합니다. 이 메서드는 클래스에서 제공되며 배열의 각 요소를 인쇄하려고합니다.ClassCastException toArray() 메서드 사용에서

이 메서드는 로컬 배열을 복사하고 Object 형식의 복사 배열을 반환합니다. 시험에

public T[] toArray() { 
    T[] copy = (T[]) new Object[this.size()]; 
    for (int i = 0; i < this.size(); i++) { 
     copy[i] = (T) this.myArray[i]; 
    } 

    return copy; 
} 

, 나는 아래 등 문자열 배열을 설정 :

개인 ArrayBasedStack 스택;

public void setUp(){ 
    stack = new ArrayBasedStack<String>(); 
} 

이 toArray() 메소드를 테스트하기 위해, 나는 시도 :

public void testToArray(){ 
     stack.push("000"); 
     stack.push("111"); 
     assertEquals(2, stack.toArray().length); 
     assertEquals("111", stack.toArray()[0]); 
    } 

다른 toArray 이상() 메소드는, 다른 방법 '시험뿐만 아니라 같은 전달 : peek(), push(), clear(), equals() ... 등

는 그러나,이 테스트는 두 assertEquals에 대한 오류를 반환

assertEquals(2, stack.toArray().length); 
    assertEquals("111", stack.toArray()[0]); 

오류 : 여기

>java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to [Ljava.lang.String; 
     at arraystack.ArrayBasedStackTest.testToArray(ArrayBasedStackTest.java:82) 
     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
     at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
     at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
     at java.lang.reflect.Method.invoke(Unknown Source) 
     at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50) 
     at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 
     at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47) 
     at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 
     at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26) 
     at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27) 
     at org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:298) 
     at org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:292) 
     at java.util.concurrent.FutureTask.run(Unknown Source) 
     at java.lang.Thread.run(Unknown Source) 
+4

음, 네가'Object []'을 만들고, 그것을 호출 할 때, 효과적으로'String []'에 형변환하고 그 형 변환은 유효하지 않다. 기본적으로, 실행 시간에 요소 유형을 실제로 알지 못하더라도 올바른 종류의 배열을 만들 수 없습니다. –

+0

'Arrays.copyOf()'를 사용하여 내부 배열을 복사 해 보았습니까? 그런 식으로 * T [] (즉,'String []')을 얻을 수 있어야합니다. 캐스팅도 필요하지 않았습니다. –

+1

도움이 될 수 있습니다 : http://stackoverflow.com/questions/529085/how-to-create-a-generic-array-in-java – uoyilmaz

답변

2
T[] copy = (T[]) new Object[this.size()]; 

컴파일러에 누워있다. T[]Object[] 인 경우가 아니면 T[]이 아닙니다.

import java.lang.ref.Array; 

public T[] toArray(T[] a) 
{ 
    if (a.length != this.size()) 
    { 
     a = Array.newInstance(a.getClass().getComponentType(), this.size()); 
    } 
    for (int i = 0; i < this.size(); i++) 
    { 
     a[i] = (T) this.myArray[i]; 
    } 
    return a; 
} 

또는 대안 :

import java.util.Arrays; 

public T[] toArray(T[] a) 
{ 
    return Arrays.copyOf(this.myArray, this size()); 
} 

이 방법을 쓸 수있는 올바른 방법은 당신이 운이 좋다면 이미 적당한 크기입니다 프로토 타입을 제공함으로써, Collections이 그것을 같은 방식입니다