zoukankan      html  css  js  c++  java
  • 用户级线程demo

    http://blog.csdn.net/dabing69221/article/details/17426953

    前言:

       前几天复习了一下多线程,发现有许多网上讲的都很抽象,所以,自己把网上的一些案例总结了一下!

    一. Thread.yield( )方法:

    使当前线程从执行状态(运行状态)变为可执行态(就绪状态)。cpu会从众多的可执行态里选择,也就是说,当前也就是刚刚的那个线程还是有可能会被再次执行到的,并不是说一定会执行其他线程而该线程在下一次中不会执行到了。

    Java线程中有一个Thread.yield( )方法,很多人翻译成线程让步。顾名思义,就是说当一个线程使用了这个方法之后,它就会把自己CPU执行的时间让掉,让自己或者其它的线程运行。

    打个比方:现在有很多人在排队上厕所,好不容易轮到这个人上厕所了,突然这个人说:“我要和大家来个竞赛,看谁先抢到厕所!”,然后所有的人在同一起跑线冲向厕所,有可能是别人抢到了,也有可能他自己有抢到了。我们还知道线程有个优先级的问题,那么手里有优先权的这些人就一定能抢到厕所的位置吗? 不一定的,他们只是概率上大些,也有可能没特权的抢到了。

    例子:

    1. package com.yield;  
    2.   
    3. public class YieldTest extends Thread {  
    4.   
    5.     public YieldTest(String name) {  
    6.         super(name);  
    7.     }  
    8.   
    9.     @Override  
    10.     public void run() {  
    11.         for (int i = 1; i <= 50; i++) {  
    12.             System.out.println("" + this.getName() + "-----" + i);  
    13.             // 当i为30时,该线程就会把CPU时间让掉,让其他或者自己的线程执行(也就是谁先抢到谁执行)  
    14.             if (i == 30) {  
    15.                 this.yield();  
    16.             }  
    17.         }  
    18.     }  
    19.   
    20.     public static void main(String[] args) {  
    21.         YieldTest yt1 = new YieldTest("张三");  
    22.         YieldTest yt2 = new YieldTest("李四");  
    23.         yt1.start();  
    24.         yt2.start();  
    25.     }  
    26. }  

    运行结果:

    第一种情况:李四(线程)当执行到30时会CPU时间让掉,这时张三(线程)抢到CPU时间并执行。

    第二种情况:李四(线程)当执行到30时会CPU时间让掉,这时李四(线程)抢到CPU时间并执行。

  • 相关阅读:
    一日一技:微信开发-自定义菜单
    Redis五种数据结构
    .NET 5 部署在docker上运行
    一日一技:微信开发-发送模板消息
    Redis快速入门及应用
    面试官扎心一问:防止重复请求提交,有什么方案?
    在Windows上安装Docker
    上班摸鱼神器—VSCode 里也可以看股票 & 基金实时数据
    C# Nuget程序集StackExchange.Redis操作Redis 及 Redis 视频资源 及 相关入门指令 牛逼不,全都有
    Mongodb 更新某一条记录 C#
  • 原文地址:https://www.cnblogs.com/feng9exe/p/6803318.html
Copyright © 2011-2022 走看看