标签:定位 sync 日期 1.3 代码 表格 代码块 同步问题 tab
标签(空格分隔): Java
本次PTA作业题集多线程
答:
作用:
BallRunnable类实现了Runnable接口之后,可以多个程序的线程处理同一资源,其中运用run()方法给线程分配任务。run()方法中通过循环用move()方法来控制小球的移动,用reprint()方法来重画轨迹,Treep.sleep()方法实现休眠。
原因:
Treep.sleep()方法是让线程进行休眠一段时间,因为系统执行这个移动小球和重画的过程非常的快,如果不休眠一段时间,我们运行起来是看不到小球的运动轨迹的。
答:
两件事:
BallComponent对象:
内部的ArrayList:
用来动态存储多个小球的对象
运行过程:
生成了1个BallComponent对象
多线程技术:
是在不同的线程中绘制的。代码运行起来后,点击Start按钮,每点击一次生成一个小球,然后小球按照规定轨迹运行。生成的小球即一个线程,故每个小球都是在自己的线程中进行的绘制。
答:
因为在move()方法中控制小球的移动,其中控制的方法都牵扯到了变量x,y,dx,dy。所以,如果在最开始生成x,y,dx,dy变量时就都随机的话,那么小球的运动轨迹和运动时间都对完全不同,即更改如下图:
运行结果:
并回答:a)通过定义Runnable接口的实现类来实现多线程程序比通过继承自Thread类实现多线程程序有何好处?b) 6-1,6-3,6-11实验总结。
Runnable接口好处:
public class xx extends Thread{
int num = 0;
public void run(){
for(int i = 0; i < 10; i++){
System.out.println(++num);
}
}
//运行主函数
public static void main(String[] args){
new xx().start(); //没new一次,就会产生一次num
new xx().start(); //这个new,那么num属于这个的。
}
}
//下面是implementes Runnable接口
public class xx implementes Runnable{
xxxx//这里代码如上
public static void main(String[] args){
xx x1 = new xx();
Thread t1 = new Thread(x1);
t1.start();
Thread t2 = new Thread(x1);
t2.start();
//这里我们可以看到,无论创建几个线程,都是传入的x1
}
}
6-1,6-3,6-11实验总结:
jmu-Java-07多线程-Thread:
这道题重点在于题目中n值的传入,所以要在类中定义一个有参构造函数,将传入的n值保存下来,其他的按照要求即可
jmu-Java-07多线程-Runnable与匿名类:
这道题重点在于主线程和t1线程的名称:
System.out.println(mainThreadName);
System.out.println(Thread.currentThread().getName());
其他就补全run()方法就好了
jmu-Java-07多线程-PrintTask:
这道题和6-1没有什么不同啊= =。 可能只有标示信息不一样吧
答:
Thread t1 = new Thread(() -> {
System.out.println(mainThreadName);
System.out.println(Thread.currentThread().getName());
System.out.println(Arrays.toString(Thread.class.getInterfaces()));
});
答:
Thread类中的stop()方法因为强行终止,不能保证线程的资源正确释放已经被废弃,现在正确的停止方式是设置一个private volatile boolean flag = false;
来终止线程,当flag==true时停止。即在run()方法里设置while(!flag)循环来起到终止线程的作用。
答:
分析:
由于在两个run()方法里,分别有调用Counter.addId();和Counter.subtractId();方法,即这两个方法为共享资源,为实现同步访问,只要在共享资源加上synchronized实现加锁即可。
代码:
运行结果:
参考资料:Java多线程之Executor、ExecutorService、Executors、Callable、Future与FutureTask
使用Future、Callable:
完成题集6-4(互斥访问)与6-5(同步访问)
答:
可以用synchronized的同步代码块来实现互斥访问。
原图:
现在:
答:
同步方法直接在方法上加synchronized实现加锁,同步代码块则在方法内部加锁,很明显,同步方法锁的范围比较大,而同步代码块范围要小点,同步的范围越大,性能就越差,需要加锁进行同步的时候,范围越小越好,这样性能更好。
答:
原理:通过给共享的资源加锁,共享资源只能允许一个线程访问。
为了测试synchronized同步代码块或者同步方法时,线程的状态是怎么变化的,测试代码如下图:
结果:
分析:
在线程1调用A后,会让线程1休眠五秒钟,这时会调用C,因为C用的是synchronized进行加锁,这里锁的对象是str这个字符串对象。而B的不同,B是用当前对象this进行加锁,又因为A直接在方法上加synchronized,显然这两个方法用的通一把锁。
从结果看,线程1在休眠,这时锁还没释放,导致线程2只有在5秒之后才能调用方法B,所以可知两种加锁机制用的是同一个锁对象,即当前对象。
答:
用wait()、notify()notifyAll()方法来协调线程之间运行关系,也可以用条件对象Condition搭配Lock对象使用。
答:
结果不正常,每次蹦的结果不一致,并且可以发现存取后有剩余。
原因:
分析应该是取货时如果无法取出货物,就有消耗了一次取货的机会,并没有等待生产者的供应,那么就导致产生了剩余。
截图:
结果:
截图:
结果:
实验任务书中的题目6:单元测试使用JUnit4。
使用JUnit4对两个排序算法的排序时间进行比较,并截图。
题目集:多线程
在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图
必须出现几个要素:提交日期-用户名(姓名与学号)-不提交说明
需要有两张图(1. 排名图。2.PTA提交列表图)
需要将每周的代码统计情况融合到一张表中。
周次 | 总代码量 | 新增代码量 | 总文件数 | 新增文件数 |
---|---|---|---|---|
1 | 0 | 0 | 0 | 0 |
2 | 0 | 0 | 0 | 0 |
3 | 0 | 0 | 0 | 0 |
4 | 0 | 0 | 0 | 0 |
5 | 1167 | 1167 | 26 | 26 |
6 | 1830 | 663 | 32 | 6 |
7 | 2282 | 452 | 45 | 13 |
8 | 2446 | 164 | 48 | 3 |
9 | 2774 | 328 | 56 | 8 |
10 | 3313 | 539 | 65 | 9 |
11 | 3726 | 413 | 75 | 10 |
12 | 4840 | 1114 | 93 | 18 |
观看相关调试视频
参考资料:Eclipse 的一些调试技巧
201621123037 《Java程序设计》第11周学习总结
标签:定位 sync 日期 1.3 代码 表格 代码块 同步问题 tab
原文地址:http://www.cnblogs.com/qin-yu/p/7942581.html