java多线程(3)Thread的静态方法

上文介绍了Tread的实例方法,本文再介绍下Thread的静态方法。

currentThread()

currentThread方法返回当前线程的Object

public  class Thread1 extends Thread{
    static{
        System.out.println(Thread.currentThread().getName()+" --> static");
    }

    public Thread1() {
        System.out.println(Thread.currentThread().getName()+" --> 构造方法");
    }
    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName()+" --> run");
    }
}
public static void main(String[] args) {
    Thread1 t1 = new Thread1();
    t1.start();
}

执行结果:

main --> static
main --> 构造方法
Thread-0 --> run

Thread1在初始化的过程中都是在主线程执行,start后开启新线程执行。

sleep()

sleep方法是事当前线程睡眠(暂停)n毫秒。在睡眠过程中,线程会让出cpu,但不会失去已锁定的资源。

        Thread t = new Thread(new Runnable() {
            @Override
        public void run() {
                try {
                    Long t1 = System.currentTimeMillis();
                    System.out.println("start at:"+t1);
                    Thread.sleep(2000);
                    Long t2 = System.currentTimeMillis();
                    System.out.println("end at:"+t2);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        });
        t.start();

执行结果:

start at:1511096714406
end at:1511096716407

考虑到系统时间分配等因素,执行结果都会大于等于指定的毫秒数,但不会差太多。另外sleep方法会抛出InterruptedException 的异常,在上文中也有讲到。

yield()

yield方法是让出cpu的使用,让出多少时间是不确定的。

public class YieldTest extends Thread{

    public YieldTest(String name) {  
        super(name);  
    }  

    @Override  
    public void run() {  
        for (int i = 1; i <= 50; i++) {  
            System.out.println("" + this.getName() + "-----" + i);  
            if (i == 30) {  
                this.yield();  
            }  
        }  
    }  

    public static void main(String[] args) {  
        YieldTest yt1 = new YieldTest("张三");  
        YieldTest yt2 = new YieldTest("李四");  
        yt1.start();  
        yt2.start();  
    }  
}

部分的执行结果:

......
张三-----28
张三-----29
张三-----30
李四-----17
李四-----18
李四-----19
李四-----20
.....

当然每次执行的结果可能都不一样,这里可以看在执行到i==30时,’张三’让出了cpu使用,’李四’则开始执行。

interrupted()

返回当前线程是否被中断,实现就是

 return currentThread().isInterrupted(true);

holdsLock(Object obj)

holdsLock是判断某个资源是否被线程锁定,

public  class Thread1 extends Thread{

    private Object obj = new Object();
    @Override
    public void run() {
        synchronized (obj) {
            System.out.println("holdsLock1="+Thread.holdsLock(obj));
        }
        System.out.println("holdsLock2="+Thread.holdsLock(obj));
    }

}
    public static void main(String[] args) {
        Thread1 t1 = new Thread1();
        t1.start();

执行结果:

holdsLock1=true
holdsLock2=false
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值