扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
你的run()方法里面,while (isRunning == true) {}一直在运行,等于把isRunning这个变量给锁死了,所以main()方法里thread.setRunning(false);其实是赋值失败的。所以一直在循环。
站在用户的角度思考问题,与客户深入沟通,找到普洱网站设计与普洱网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站设计、网站建设、企业官网、英文网站、手机端网站、网站推广、空间域名、网页空间、企业邮箱。业务覆盖普洱地区。
是因为main函数只是程序的入口,是一个程序中多条线程的其中一条。独立的线程间是互相不影响的,因此即便main线程结束了,其他线程依然会照常运行。
你的程序启动两个线程,一个是main ,一个是你开的线程ADaemon,而ADaemon是以 个守护线程,也就是说是在后台运行的。
你这个问题我试了下,因为只循环10次一个线程抢到10次都跑完了。所以不会出现交替。你可以把10次改成1000次看下效果你就明白了。但是不可以出现在121212这样交替情况,两个线程不可能抢到后就当好打应一次。
Java线程同步 由于同一进程的多个线程共享同一片存储空间,在带来方便的同时,也带来了访问冲突这个严重的问题。Java语言提供了专门机制以解决这种冲突,有效避免了同一个数据对象被多个线程同时访问。
设置一个计数器,每个线程执行完后计数器加一然后查看计数器是否已满(任务都完成),没有的话就阻塞,是的话就唤醒其他所有线程,大家一起来执行下一次任务。
多线程可以防止这个问题,多条线程同时运行,哪怕一条线程的代码执行读取数据阻塞,也不会影响其它任务的执行。(3)便于建模 这是另外一个没有这么明显的优点了。
通过while(true)循环判断exe.isTerminated()的值,为了防止过多的判断浪费资源,可设置线程睡眠Thread.sleep(200);正是由于这个睡眠,所以当所有线程池中的线程都执行完后,有可能延迟200ms才执行结束了语句。
已经开启所有的子线程 子线程[3]开启 子线程[7]开启 子线程[10]开启 shutdown():启动一次顺序关闭,执行以前提交的任务,但不接受新任务。
调用shutdown(),线程池就会不再接受任务。 然后调用public boolean awaitTermination(long timeout, TimeUnit unit) 等待所有任务执行完毕,执行完毕返回true或者超时返回false。
1,通过Thread.activeCount()方法判断当前线程的线程组中活动线程的数目,为1时其他线程运行完毕;2,通过java.util.concurrent.Executors中的方法创建一个线程池,用这个线程池来启动线程。
xx.shutdown xx.isTerminated 如果关闭后所有任务都已完成,则返回 true。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流