Gra*_*ta1 1 java multithreading
我是多线程的新手,我只是尝试使用线程打印14000大小的字符串Arraylist来实践练习.我不是在考虑这个问题的效率,也不考虑有用性; 我只是想了解线程概念.
我的输出非常错误,我尝试了各种同步和其他失败的尝试.我现在遇到了一个名为join的工具,但是我的程序没有退出并继续运行.我调试了代码,程序只是卡在第一个线程连接上,我想不出任何理由或解决方案来解决问题.
我解决问题的方法是创建4个线程来分割打印任务.然后我会等到所有线程都完成并在关闭输出文件之前使用连接权限.
public class Threadprinting implements Runnable{
private static List<String> list;
private Thread T1,T2,T3,T4;
public void printinput(List<String> store){
list=new ArrayList<String>(store);
Threadprinting threadprinting=new Threadprinting();
Threadprinting.generatethreads();
}
public void generatethreads() {
T1=new Thread(this,"t1");
T1.start();
T2=new Thread(this,"t2");
T2.start();
T3=new Thread(this,"t3");
T3.start();
T4=new Thread(this,"t4");
T4.start();
}
public void run(){
try {
PrintWriter out = new PrintWriter(new FileWriter("Output.txt"));
switch (Thread.currentThread().getName()) {
case "t1":
System.out.println("Thread "+ Thread.currentThread().getName() + " is running");
for (int i = 0; i < list.size() / 4; i++) {
out.println((list.get(i)));
}
break;
case "t2":
System.out.println("Thread "+ Thread.currentThread().getName() + " is running");
for (int i = list.size() / 4; i < list.size() / 2; i++) {
out.println((list.get(i)));
}
break;
case "t3":
System.out.println("Thread "+Thread.currentThread().getName()+" is running");
for (int i = list.size()/2; i < list.size()/4+list.size()/2; i++) {
out.println((list.get(i)));
}
break;
case "t4":
System.out.println("Thread "+Thread.currentThread().getName()+" is running");
for (int i = list.size()/4+list.size()/2; i < list.size(); i++) {
out.println((list.get(i)));
}
break;
default:
System.out.println("filler");
break;
}
jointhreads();
out.close();
}
catch(IOException e){
System.out.println("problem came from here");
}
}
Run Code Online (Sandbox Code Playgroud)
特别:
private void jointhreads() {
try {
T1.join();
T2.join();
T3.join();
T4.join();
} catch (InterruptedException e) {
System.out.println("the joins failed");
}
}
Run Code Online (Sandbox Code Playgroud)
}
根据调试器,程序无法终止并继续在T1.join上运行.
您正在调用jointhreads要加入的内部线程,因此
T1基本上等待T1(本身)终止但这种情况永远不会发生.
您应该jointrheads在主线程中调用,因此应用程序将等待所有工作线程完成其工作
| 归档时间: |
|
| 查看次数: |
1294 次 |
| 最近记录: |