A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 柏涛 中级黑马   /  2014-2-9 18:49  /  1438 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

import java.util.*;
import java.text.*;

public class Thread01
{
public static void main(String []args)throws Exception{

Test test = new Test();

Thread t = new Thread(test);

t.start(); //启动run 调用m1

//如果 这里加个 Thread.sleep(); 那么就m1先执行

test.m2(); //主线程 调用 m2

//问题:为什么每次运行都先执行m2 而且我把他俩优先级改了 还是每次都是 m2先执行,
}
}


class Test implements Runnable
{

public void run(){
m1();
}

public synchronized void m1(){
System.out.println("m1........");
}

public synchronized void m2(){

System.out.println("m2.........");
}
}

评分

参与人数 1技术分 +1 收起 理由
zzkang0206 + 1 赞一个!

查看全部评分

2 个回复

正序浏览
我只能说,主线程启动完线程t后,在线程t还没开始执行工作的时候,主线程瞬间就把没m2给打印出来了,然后线程t才开始打印m1。不管你有无修改优先级。因为并不是修改了优先级,线程就一定会有优先获取cpu资源的权利,只能说它抢占资源的优势提高了一点。
如果楼主真的有强迫症的话,我加了两条代码,你执行一下,确实是m1先被打印,不过并不能说明什么问题,因为主线程后来还执行了修改优先级和输出才把cpu使用权让给了t。
我的理解就是这样,楼主

  1. public static void main(String []args)throws Exception{

  2. Test test = new Test();

  3. Thread t = new Thread(test);
  4. System.out.println("主线程的优先级"+Thread.currentThread().getPriority());
  5. System.out.println("t修改前的优先级"+t.getPriority());

  6. t.start(); //启动run 调用m1
  7. t.setPriority(Thread.MAX_PRIORITY);
  8. System.out.println("t修改后的优先级"+t.getPriority());
  9. //如果 这里加个 Thread.sleep(); 那么就m1先执行

  10. test.m2(); //主线程 调用 m2

  11. //问题:为什么每次运行都先执行m2 而且我把他俩优先级改了 还是每次都是 m2先执行,
  12. }
复制代码

评分

参与人数 1技术分 +1 收起 理由
zzkang0206 + 1 赞一个!

查看全部评分

回复 使用道具 举报
主线程再启动t后并未停止,他还会继续向下执行test.m2();直接通过对象test调用m2();

评分

参与人数 1技术分 +1 收起 理由
zzkang0206 + 1 赞一个!

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马