今天写了一个多线程的应用作业。看完书本上的内容之后觉得应该很简单。题目是这样的
“
(1)创建一个站台类Station,继承Thread,重写run方法,在run方法里面执行售票操作!售票要使用同步锁:即有一个站台卖这张票时,其他站台要等这张票卖完!
(2)创建主方法调用类”
然后完成的样式是这样子的:
第一眼我还以为要构建窗口1,窗口2,窗口3,跟前天写的监视器的知识结合起来,结果定睛以看发现是console上面显示的内容。于是感觉事情一下子简单了太多,看过书本之后想通过建立三个thread派生类窗口123来完成。
但是在使用synchronization的时候碰到了问题,我构建的程序只能一路到底,不能够分担到别的线程。在尝试了一些方法之后我发掘对于票数的限制是关键,我个人的理解下,既然是用implement runnable连接起来的三个线程,那么他们就等于走了一条道,就好像三个人一起玩台球一样,按照规则来说,假设第一个人没有错误那么他就可以一直打到底,但是桌子上的台球只有那么多,打完自然也就轮不到另外两个人了,于是就可以引入thread.sleep,让其每次击打台球后都进入睡眠,给另外两个机会,但是我好奇的是这个sleep的时间足够长的话还是不能精确的控制先后顺序,按照我的理解里面的站台1sleep了很久那么在这段时间里他就不应该出现才对。这可能就涉及到了虚拟机到底如何操作了,暂时也没
笔记——有关于Java thread类 的一个作业完成 与 对于线程和同步锁(synchronization)的思考
最新推荐文章于 2019-07-05 21:17:35 发布
![](https://img-home.csdnimg.cn/images/20240711042549.png)