浏览 1615 次
锁定老帖子 主题:线程测试--疑惑
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2009-09-03
最后修改:2009-09-28
结果发现每次运行速度都不一样很纳闷。。。。。特来求教--哪出问题了? ps:网上说 Tim Peierls 用一个简单的线性全等伪随机数生成器(PRNG)构建了一个简单的评测 哪位大虾有这评测,能否提供,感激不尽! public class ReentrantLockTest { private CyclicBarrier barrier; private Object objTest; private int threadNum; public ReentrantLockTest(int threadNum) { barrier = new CyclicBarrier(threadNum + 1); this.threadNum = threadNum; } public static void main(String args[]) { int threadCount = 5000; ReentrantLockTest test4 = new ReentrantLockTest(threadCount); test4.objTest = test4.new ReentrantLockUnFair(); test4.test(); ReentrantLockTest test1 = new ReentrantLockTest(threadCount); test1.objTest = test1.new ReentrantLockFair(); test1.test(); ReentrantLockTest test2 = new ReentrantLockTest(threadCount); test2.objTest = test2.new ReentrantLockUnFair(); test2.test(); ReentrantLockTest test3 = new ReentrantLockTest(threadCount); test3.objTest = test3.new SynchronizedTest(); test3.test(); } public void test() { try { for (int i = 0; i < threadNum; i++) { new TestThread(objTest).start(); } // barrier.await(); // �ȴ����������̴߳��� // long start = System.currentTimeMillis(); // barrier.await(); // �ȴ��������������� // long end = System.currentTimeMillis(); //����һ��д�� long start = System.currentTimeMillis(); barrier.await(); // �ȴ����������̴߳��� barrier.await(); // �ȴ��������������� long end = System.currentTimeMillis(); System.out.println("����ʱ��:" + (end - start) + "����"); } catch (Exception e) { throw new RuntimeException(e); } } class TestThread extends Thread { private Object obj; public TestThread(Object obj) { this.obj = obj; } public void run() { try { barrier.await(); obj.equals(""); barrier.await(); } catch (Exception e) { throw new RuntimeException(e); } } } class ReentrantLockFair { private final Lock lock = new ReentrantLock(true); public boolean equals(Object obj){ lock.lock(); try { for(int i=0 ; i<10 ; i++){ } } finally { lock.unlock(); } return true; } } class ReentrantLockUnFair { final Lock lock = new ReentrantLock(false); public boolean equals(Object obj){ lock.lock(); try { for(int i=0 ; i<10 ; i++){ } } finally { lock.unlock(); } return true; } } class SynchronizedTest { public synchronized boolean equals(Object obj){ for(int i=0 ; i<10 ; i++){ } return true; } } } 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2009-09-04
最后修改:2009-09-04
你代码有问题
你这哪里有锁的竞争??? |
|
返回顶楼 | |
发表时间:2009-09-04
obj.equals("");
会有竞争啊!! |
|
返回顶楼 | |
发表时间:2009-09-04
axxxx2000 写道 obj.equals("");
会有竞争啊!! 每个线程都new 一个新的lock 哪来的锁竞争?? 单纯的多线程CPU竞争 如果不是因为Java把""给缓存了 synchronized("") 也不会有任何竞争 |
|
返回顶楼 | |
发表时间:2009-09-07
他执行的equal方法是同一个实例的objTest啊,个人认为有竞争的
|
|
返回顶楼 | |
发表时间:2009-09-07
synchronized (obj)
这有问题该是synchronized (this),恩,原来的是错了 |
|
返回顶楼 | |