new了2个Thread,为什么不是交叉打印?

public static void main(String[] args){

        new Thread(new Runnable() {
            @Override
            public void run() {
                for (int i=0; i<10; i++){
                    System.out.print(i+" ");
                }
            }
        }).start();

        new Thread(new Runnable() {
            @Override
            public void run() {
                for (int i=0; i<10; i++){
                    System.out.print(i+" ");
                }
            }
        }).start();
    }

输出结果如下:

0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 
小唯快跑啊
浏览 786回答 13
13回答

PIPIONE

cpu的执行速度太快,数字太小看不出差距.要是我,起码Integer.MaxValue.

当年话下

如果没有同步锁,这两个线程是不会出现你说的交叉打印的,线程的执行的优先级在于谁先获取了cpu资源,你的程序并不能保证哪个线程先执行。再好好看看java多线程知识吧。

慕森王

设置的次数太少,如果你设置100个数就能看到俩个线程交叉(这里的交叉不是线程1打印一个数,线程2马上打印一个数,而是一段一段的)打印的效果;cpu抢到资源就执行了。你要实现交叉打印的话,那是个生产这与消费者的例子。

POPMUISE

就输出完10个数字太快了,把10改成100试试。

Smart猫小萌

加上个线程休眠时间

米脂

0 0 1 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 我的是这样的!自己想吧

qq_遁去的一_1

线程是不保证执行顺序的。

慕神8447489

线程的执行顺序是不确定的,谁抢占到cpu谁就执行,十个数字的顺序也不一定是你这样的,你多执行几次就会出现不同的结果。而且线程的优先级也无法保障线程的执行次序。只不过优先级高的线程获取 CPU 资源的概率大一点而已。

阿波罗的战车

1、控制使得线程锁的顺序保持一致,可以使用java.util.concurrent.locks包里灵活的锁2、使用java.util.concurrent.atomic包的原子类

呼唤远方

CPU的执行太快了,第一个线程很快就执行完了,第二个线程估计还没有创建好,把循环的值改到1000试试,应该就能看出来效果了但肯定不会是交叉的,是混乱的
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Java