当前位置: 代码迷 >> J2SE >> 不可思议的结果。哪位高手能帮忙解释下。
  详细解决方案

不可思议的结果。哪位高手能帮忙解释下。

热度:68   发布时间:2016-04-24 14:53:50.0
不可思议的结果。。。谁能帮忙解释下。。。
运行结果:
线程1开始:帮忙     a   长江     长江   bag   东方   country   黄河  
线程2开始:黄河   country   黄河   country   可能   hello  
线程3开始:   可能   hello   你好   is   this   我     this   where   阳光  
线程4开始:阳光     where   women   字典   字典   women  
线程1结束:str_PartText[0]=帮忙     a   长江   bag   东方   country   黄河  
线程2结束:str_PartText[1]=黄河   country   可能   hello  
线程3结束:str_PartText[2]=   可能   hello   你好   is   this   我   where   阳光  
线程4结束:str_PartText[3]=阳光     where   women   字典  
线程结束
false
false
false
false
int_temp   is   :4
线程1开始:帮忙     a   长江   bag   东方   country   黄河   黄河   country   可能   hello  
线程2开始:   可能   hello   你好   is   this   我   where   阳光   阳光     where   women   字典  
线程2结束:str_PartText[1]=   可能   hello   你好   is   this   我   where   阳光   women   字典  
线程1结束:str_PartText[0]=帮忙     a   长江   bag   东方   country   黄河   可能   hello  
线程结束
false
false
int_temp   is   :2
线程1开始:帮忙     a   长江   bag   东方   country   黄河   可能   hello   帮忙     a   长江   bag   东方   country   黄河   可能   hello  
线程1结束:str_PartText[0]=帮忙     a   长江   bag   东方   country   黄河   可能   hello  
线程结束
false
int_temp   is   :1
排序结果为:
-------------------------
帮忙     a   长江   bag   东方   country   黄河   可能  
hello  


run方法为:
public   void   run(){
if(Thread.currentThread()==thr_StringSort[0]){
String   string_guibing=str_PartText[0]+str_PartText[1];
System.out.println( "线程1开始: "+string_guibing);
try{
Thread.sleep(10);
}catch(InterruptedException   e){
e.printStackTrace();
}
string_guibing=PaiChong(string_guibing);
str_PartText[0]=Sort(string_guibing);
System.out.println( "线程1结束:str_PartText[0]= "+str_PartText[0]);
}
if(Thread.currentThread()==thr_StringSort[1]){
String   string_guibing=str_PartText[2]+str_PartText[3];
System.out.println( "线程2开始: "+string_guibing);
try{
Thread.sleep(10);
}catch(InterruptedException   e){
e.printStackTrace();
}
string_guibing=PaiChong(string_guibing);
str_PartText[1]=Sort(string_guibing);
System.out.println( "线程2结束:str_PartText[1]= "+str_PartText[1]);
}
if(Thread.currentThread()==thr_StringSort[2]){
String   string_guibing=str_PartText[4]+str_PartText[5];
System.out.println( "线程3开始: "+string_guibing);
try{
Thread.sleep(10);
}catch(InterruptedException   e){
e.printStackTrace();
}
string_guibing=PaiChong(string_guibing);
str_PartText[2]=Sort(string_guibing);
System.out.println( "线程3结束:str_PartText[2]= "+str_PartText[2]);
}
if(Thread.currentThread()==thr_StringSort[3]){
String   string_guibing=str_PartText[6]+str_PartText[7];
System.out.println( "线程4开始: "+string_guibing);
try{
Thread.sleep(10);