1)总体介绍:网上搜索有各种说法
2)错误的理解:
3)正确的理解:2种,Oracle官网文档(
一种声明thread类;run()整个都被重写 缺点:没有解耦
另一种方法是一个实现Runnable接口的类,然后该类实现run方法;最终调用target.run() 该方法更好:解耦 资源节约
)
1.从代码架构角度:具体的任务(run方法)应该和“创建和运行线程的机制(Thread类)”解耦,用runnable对象可以实现解耦。
2.使用继承Thread的方式的话,那么每次想新建一个任务,只能新建一个独立的线程,而这样做的损耗会比较大
(比如重头开始创建一个线程、执行完毕以后再销毁等。如果线程的实际工作内容,也就是run()函数里只是简单的打印一行文字的话,
那么可能线程的实际工作内容还不如损耗来的大)。如果使用Runnable和线程池,就可以大大减小这样的损耗。
3.继承Thread类以后,由于Java语言不支持双继承,这样就无法再继承其他的类,限制了可扩展性。
src.threadcoreknowledge.createthreads
1)start()和run()的比较
2)start()方法原理解读
3)run()方法原理解读
4)常见面试题
1)原理介绍
2)如何正确停止线程
3)错误的停止方法
4)停止线程相关的重要函数解析
5)常见面试问题
5.Thread和Object类种和线程相关的重要方法
7.线程的未捕获一场UncaughtException应该如何处理?
8.多线程会导致性能问题(线程引入的开销、上下文切换)