java - 使用 toArray() 方法引发的 ClassCastException

标签 java

我正在为 toArray 方法编写 junit 测试,该方法是 ArrayBasedStack 的方法之一。该类内部有一个数组,toArray 方法复制元素并返回。该方法是由类给出的,我正在尝试打印出数组中的每个元素。

此方法复制本地数组并返回具有对象类型的复制数组。

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;
}

为了测试,我设置了字符串数组,如下所示:

私有(private)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)

最佳答案

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

你在这里对编译器撒谎。它不是 T[],除非 T[]Object[]

编写此方法的正确方法与Collections 的做法相同,通过提供一个原型(prototype),如果幸运的话,该原型(prototype)已经是正确的大小:

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());
}

关于java - 使用 toArray() 方法引发的 ClassCastException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39626591/

相关文章:

java - 使用开关盒油漆组件选择颜色(下拉列表中的值)

java - 在 Linux 中创建跨平台安装程序

java - 字符串构造函数_网络

java - 在 Spring 中模拟用户

java.lang.OutOfMemory错误: Java heap space in IntelliJ

java - 保存多阶段jsp表单的数据

java - 使用 Java 输出流

java - 在Java中,如果父类有psvm,为什么我们不能使用名称为String的内部类

java - 可序列化的单例类

java - 在 TopDocs.scoreDocs 循环中删除 Lucene 文档而不使用唯一 id