Thread.sleep小感

本文介绍了一个使用Java实现的多线程日志处理程序案例。该程序通过创建四个线程并采用同步机制来确保16条日志能够均匀地在四秒内处理完成。文章展示了如何利用synchronized关键字来控制线程间的同步访问,并提供了完整的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package com.ethan.kongzhong;

public class Test1 implements Runnable {  
    
	private Integer monitor = 0;
	
//	private int i =0;
    public static void main(String[] args){  
         
        System.out.println("begin:"+(System.currentTimeMillis()/1000));  
        /*模拟处理16行日志,下面的代码产生了16个日志对象,当前代码需要运行16秒才能打印完这些日志。 
        修改程序代码,开四个线程让这16个对象在4秒钟打完。 
        */  
        
        Test1 t = new Test1();
        
        new Thread(t).start();
        new Thread(t).start();
        new Thread(t).start();
        new Thread(t).start();
    }
    
    public void run() {
        for(int i=0;i<16;i++){  //这行代码不能改动 
//    	  for(;i<16;i++) {
        	synchronized(monitor) {
        		i = monitor;
        		monitor++;
        	}
            final String log = ""+(i+1);//这行代码不能改动  
            {  
                    Test1.parseLog(log);  
            }  
            
            i = monitor-1;
            //i++;
        }  
    }  
      
    //parseLog方法内部的代码不能改动  
    public static void parseLog(String log){  
          
        try {  
        	//1秒后不一定立马执行,得等分配到处理器。但1秒后会释放锁。
            Thread.sleep(1000);  
            System.out.println(Thread.currentThread().getName()+log+":"+(System.currentTimeMillis()/1000));  
        } catch (InterruptedException e) {  
            e.printStackTrace();  
        }         
    }  
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值