簡體   English   中英

從main獲得不同的輸出

[英]Getting different output from main

package com.test.scjp;

import java.util.List;
import java.util.ArrayList;

public class TestGeneric {
    public static void main(String args[]){
        try{
            List<String> l = new ArrayList<String>();
            TestGeneric t = new TestGeneric();
        //t.test(l);
            System.out.println("Test");
            l=t.test(l);
            System.out.println("Test2");

            System.out.println(l.get(0));
        }
        catch(Exception e){
            e.printStackTrace();
        }
    }
    public List<String> test(List l){
        System.out.println("Test0");
        l.add(new Integer(1));
        System.out.println("Test1");
        return l;
    }
}

當我運行此代碼20次時,我得到不同的輸出:

輸出1:

Test
Test0
Test1
Test2
java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String
    at com.test.scjp.TestGeneric.main(TestGeneric.java:16)

輸出2:

Test
Test0
java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String
    at com.test.scjp.TestGeneric.main(TestGeneric.java:16)
Test1
Test2

System.outSystem.err在不同的線程上工作。 兩個線程在不同時間訪問共享資源( 控制台 )。

另請參閱System.out和System.err調用的隨機打印順序Java:System.out.println和System.err.println亂序

在內部測試中,您的列表不是Generic - 因此您可以向其添加任何Object。

問題是,除了它之外,你使用的是一個僅限於字符串的List。

它的這種沖突導致了你的問題。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM