zoukankan      html  css  js  c++  java
  • java多线程之yield()方法详解

         yiled()方法的作用是放弃当前CPU的资源,将资源让给其它线程,但放弃的时间不确定,有可能刚刚放弃,又马上获得了CPU时间片。下面看一个小例子,看一下具体效果。	public static void main(String[] args) throws InterruptedException {
    
    		MyThread t = new MyThread();
    		t.start();
    		Thread.sleep(2);
    		for (int i = 0; i < 9000; i++) {
    
    			System.out.println("i=" + i);
    		}
    	}
    
    	public static class MyThread extends Thread {
    
    		private long beginTime = System.currentTimeMillis();
    		private int count = 0;
    
    		@Override
    		public void run() {
    			super.run();
    			for (int i = 0; i < 1000; i++) {
    yield(); count = count + (i + 1); System.out.println("count=" + count); } long endTime = System.currentTimeMillis(); System.out.println("用时:" + (endTime - beginTime) + "毫秒"); } }
    
    
      看一下运行结果:

    前三段是第一次运行的结果,可以看出来主线程和子线程是交替出现的,count是子线程打印的结果,i是主线程打印的结果。第四段和第五段分别是我第二次和第三次运行的结果,可以看出子线程运行的时间是不一样的,也就是子线程让出cpu的时间是不固定的。
        
     
  • 相关阅读:
    线程执行器(一)
    修改锁的公平性
    Spark学习视频整合
    使用读写锁实现同步数据访问
    使用锁实现同步
    使用工厂类创建线程
    线程的分组
    android手机状态解释,比方android.os.Build.VERSION.SDK
    Android-Dalvik指令集
    selenium使用Xpath定位之完整篇
  • 原文地址:https://www.cnblogs.com/chentong/p/5619971.html
Copyright © 2011-2022 走看看