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
CPUの実行速度が速すぎて、数値が小さすぎて違いがわかりません。私だったら、少なくとも
。Integer.MaxValue
.同期ロックがない場合、2 つのスレッドは前述のクロスプリントを実行しません。スレッドの実行の優先順位は、どちらが最初に CPU リソースを取得するかによって決まります。プログラムはどちらのスレッドが最初に実行されるかを保証できません。 Java マルチスレッドの知識を詳しく見てみましょう。
設定数が少なすぎると、2 つのスレッドが交差する印刷効果がわかります (ここでの交差とは、スレッド 1 が数値を出力し、スレッド 2 がすぐに数値を出力するということではなく、セグメントごとに行われます)。 ; cpu リソースを取得したらすぐに実行します。クロスプリントを実装する場合、これはプロダクションとコンシューマーの例です。
10 個の数値を出力するには速すぎます。10 を 100 に変更してみてください。
スレッドのスリープ時間を追加します
0 0 1 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 私の場合はこんな感じです
2 つの for ループの出力ステートメントの前に Thread.sleep(1000) を追加します。
再試行してください
スレッドは実行順序を保証しません。
スレッドの実行順序は不確実であり、10 個の数字の順序は、何度か実行すると異なる結果が表示されます。また、スレッドの優先順位はスレッドの実行順序を保証するものではありません。優先順位の高いスレッドの方が CPU リソースを獲得できる可能性が高いというだけです。
リーリー
このように、比較的明らかなクロスプリント現象が見られますが、実際には、同時実行性とは、どのスレッドが最初に実行され、どのスレッドが後で実行されるかがわからないことを意味し、必ずしもクロスオーバーが発生することを意味するわけではありません。大げさに言えば、2 スレッドのアセンブリ命令を m, n 個挿入することで、複数の階乗レベルの実行シーケンスが可能になります。