public class MyRunnable implements Runnable {
@Override
public void run() {
System.out.println(Thread.currentThread().getName());
}
}
public class Client {
public static void main(String[] args) {
Runnable r = new MyRunnable();
Thread t = new Thread(r, "Demo");
ExecutorService service = Executors.newFixedThreadPool(2);
service.submit(t);
service.shutdown();
}
}
输出结果为:pool-1-thread-1
预期结果为:Demo
ExecutorService.submit
接受的是Runnable
接口的实现,而不是Thread
,线程池拿到Runnable
接口的实现之后,只关心一个run方法,并且也只会调用它。
至于你拿到的线程名,是线程池生成时已经生成的(newFixedThreadPool时),和你submit的那个t无关
去阅读下Thread
的run方法和AbstractExecutorService
的submit方法的代码应该对你理解有所帮助
如果你真的有对线程名有要求,应该在线程内部改(也就是Runaable的run方法内),这样获取到的线程才是当前线程
(当然每次你都要取一次以确认,因为没法确保下次还是同一个线程运行这个Runnable).
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。