Java阻塞多长时间_java多線程應用程序:正在線程阻塞時間

可以試一下,喜歡的東西:

import java.lang.management.ManagementFactory;

import java.lang.management.ThreadInfo;

import java.lang.management.ThreadMXBean;

public class BlockedTimeMain {

public static void main(String[] _) throws InterruptedException {

ThreadMXBean mbean = ManagementFactory.getThreadMXBean();

mbean.setThreadContentionMonitoringEnabled(true);

final Object lock = new Object();

Thread t = new Thread("Foo") {

@Override public void run() {

// This will block forever

synchronized(lock) {

// Will never get here

System.out.println("Got the lock from " + Thread.currentThread());

}

}

};

synchronized(lock) {

t.start();

for (;;) {

ThreadInfo[] tis = mbean.getThreadInfo(new long[]{t.getId()}, true, true);

ThreadInfo ti = tis[0];

if (ti.getThreadId() != t.getId())

throw new AssertionError("Unexpected " + t.getId() + " vs " + tis[0].getThreadId());

System.out.println(t + " " + ti.getThreadState()

+ ": blockedTime=" + ti.getBlockedTime() + "/" + ti.getBlockedCount()

+ ", waitTime" + ti.getWaitedTime() + "/" + ti.getWaitedCount());

Thread.sleep(1000);

}

}

}

}

樣本輸出:

Thread[Foo,5,main] BLOCKED: blockedTime=2/1, waitTime0/0

Thread[Foo,5,main] BLOCKED: blockedTime=1007/1, waitTime0/0

Thread[Foo,5,main] BLOCKED: blockedTime=2012/1, waitTime0/0

Thread[Foo,5,main] BLOCKED: blockedTime=3016/1, waitTime0/0

Thread[Foo,5,main] BLOCKED: blockedTime=4021/1, waitTime0/0

Thread[Foo,5,main] BLOCKED: blockedTime=5025/1, waitTime0/0

Thread[Foo,5,main] BLOCKED: blockedTime=6028/1, waitTime0/0

Thread[Foo,5,main] BLOCKED: blockedTime=7032/1, waitTime0/0

Thread[Foo,5,main] BLOCKED: blockedTime=8035/1, waitTime0/0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值