java使用多线程找出最大随机数

时间:2021-05-19

本文实例为大家分享了java用多线程找出最大随机数的具体代码,供大家参考,具体内容如下

问题: 系统随机生成 10000 个数,构造 5 个线程并利用它们的 Join 方法计算这些随机数的最大值。

思路:

1)、定义一个全局变量AllMax来记录在最大值

2)、自定义myThread类继承自Thread,重写run函数。

3)、Run函数,循环两千次,每次产生一个10000以内的随机数,与AllMax进行比较,若大于AllMax,则立即将AllMax更新。

4)、实例化MyThread,创建五个线程,同步执行。使用jion函数,等各线程执行完,则输出AllMax

public class four2 { static long AllMax=-1; public static void main(String[] args) { // TODO Auto-generated method stub MyThr t1=new MyThr(); MyThr t2=new MyThr(); MyThr t3=new MyThr(); MyThr t4=new MyThr(); MyThr t5=new MyThr(); t1.start(); t2.start(); t3.start(); t4.start(); t5.start(); try { t1.join(); t2.join(); t3.join(); t4.join(); t5.join(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println("10000个数中的最大值为:"+AllMax); } public static class MyThr extends Thread{ public void run(){ long rand; for(int i=1;i<=2000;i++){ rand=(long)(Math.random()*100000)%100000; //System.out.println(rand); if(rand>AllMax){ AllMax=rand; } } } } }

--------------后话------------------

按照平时用的选择最大随机数的方法和多线程方法比较,所用时间还是普通方法快。

以下是测试对比图:

1.传统方法:

2.多线程方法所用时间:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章