代码拉取完成,页面将自动刷新
Java 给多线程编程提供了内置的支持。 一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。 多线程是多任务的一种特别的形式,但多线程使用了更小的资源开销。 进程:一个进程包括由操作系统分配的内存空间,包含一个或多个线程。一个线程不能独立的存在,它必须是进程的一部分。一个进程一直运行,直到所有的非守护线程都结束运行后才能结束。 多线程能满足程序员编写高效率的程序来达到充分利用 CPU 的目的。
线程是一个动态执行的过程,它也有一个从产生到死亡的过程。
public class TraditionalThread {
public static void main(String[] args) {
//匿名内部类(继承Thread类)创建方式
new Thread(){
@Override
public void run() {
System.out.println(this.getName());
}
}.start();
//传入Runnable对象
Thread thread=new Thread(new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName());
}
});
thread.start();
}
}
查看Thread类的run()方法源代码,可以知道以上两种方式都是在调用Thread对象的run()方法,
当Thread类的run()方法没有被子类覆盖时,并且为该Thread类传入了Runnable对象时,执行的是Runnable对象中的run()方法;反之,执行的
是Thread类自身的run()方法。
public class TraditionalThread {
public static void main(String[] args) {
//匿名内部类创建方式
new Thread(new Runnable() {//通过父类构造方法传入的Runnable对象
@Override
public void run() {
System.out.println(Thread.currentThread().getName());
}
}){
//运行的是这段子类的代码
@Override
public void run() {
System.out.println(this.getName());
}
}.start();
}
}
在单核CPU中,多线线程机制不会提高运行效率,一般来说,反而会降低效率。因为CPU在各个线程上的切换会消耗时间。
其实计算机本身没有变快,只是服务器为每个线程分配了带宽,服务器可同时为多个线程提供服务。
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。