标签:thread 对象 2.4 其他 合作 run 实验 时间段 lambda
使用Runnable接口实现多线程可以更加方便地实现数据共享的概念。
优先级越高的线程对象,越有可能先执行
本次作业题集 多线程
Thread.sleep
进行休眠?有利于观察多个球的运动轨迹,如果不加入休眠的话,运行完之后此线程很快结束显示的就只是小球最终的位置了,看不到运行轨迹
在点击start
按钮的时候,每点击一下都会生成一个小球运动,可见每个小球是在不同的线程中进行绘制。
a)通过定义Runnable
接口的实现类来实现多线程程序比通过继承自Thread
类实现多线程程序有何好处?
b) 6-1,6-3,6-11实验总结。
Thread
类,以此继承其中的start()
方法,然后在通过覆写run()
方法满足题目要求。implements
关键字实现Runnable
接口,并覆写当中的run()
方法实现题目要求6-3:通过创建匿名Thread对象和匿名Runnable接口对象new Thread(new Ruannble(){})
而后通过匿名内部类的形式覆写run()
方法,这种方法比前两种更加简洁
run
的运行,在这里,如果flag为true就停止,为false就进行,可以创建一个stopMe()方法来修改flag变量的值。完成题集6-4(互斥访问)与6-5(同步访问)
synchronized
关键字以及(this)
获取当前线程对象,然后再进行同步操作,是在方法内部实现同步方法:是通过synchronized
关键字声明方法,使之在调用该方法的时候就进行同步操作。
通过使用synchronized
关键字,使得当有线程再使用这一部分程序的时候,给程序上锁,此时如果有其他线程要访问这些内容就需要等待锁被解开,当在使用的线程操作完后,将锁解开,此时其他线程可以进行访问。
就像此代码运行结果,只有当A线程执行完之后才可以轮到其他线程执行卖票操作
wait,notify关键字以及volatile关键字
运行结果不正常,结果显示在运行过程中仓库已经满了的情况下,添加货物的操作无法进行但是仍然计数了,所以导致最后剩余的货物不为0
synchronized, wait, notify
解决该问题(关键代码截图,需出现学号)题目集:多线程
需要有两张图(1. 排名图。2.PTA提交列表图
需要将每周的代码统计情况融合到一张表中。
周次 | 总代码量 | 新增代码量 | 总文件数 | 新增文件数 |
---|---|---|---|---|
1 | 120 | 120 | 2 | 2 |
2 | 280 | 160 | 5 | 3 |
3 | 590 | 310 | 10 | 5 |
4 | 780 | 190 | 12 | 2 |
5 | 1290 | 510 | 17 | 5 |
6 | 1710 | 420 | 20 | 3 |
7 | 2513 | 803 | 24 | 4 |
8 | 2513 | 0 | 24 | 0 |
9 | 3014 | 501 | 27 | 3 |
10 | 3441 | 327 | 30 | 3 |
11 | 4121 | 680 | 37 | 7 |
12 | 4667 | 546 | 42 | 5 |
标签:thread 对象 2.4 其他 合作 run 实验 时间段 lambda
原文地址:http://www.cnblogs.com/suwl/p/7955380.html