浅析进程、线程、纤程
进程、线程、纤程:
概念:
进程:一个运行的程序
线程:一个运行程序中的执行队列,一个进程有多个线程
纤程:一般指线程中线程;线程启动时调用的是内核空间,纤程启动时调用的是用户空间。线程之间的切换是重量级的,消耗资源较多;而纤程切换是轻量级的,消耗资源较少。线程是内核空间的多个程序流并发;纤程是用户空间的多个程序流并发。
例如:Linux分两个系统级别,一个是用户空间(user),一个是内核空间(kernel),当启动线程时需要调用内核空间所以导致线程之间的切换会比较重量级,消耗资源较多;为了提高效率,将线程挪到用户空间,消耗的资源会比较低,效率比较高。这就是纤程。每个纤程都有自己的栈,其切换也是通过栈来切换的。
总结:纤程是用户态的线程,是线程中的线程。切换和调度不需要经过操作系统,轻量级的线程;JAVA一直到JDK13都不直接支持纤程,如果要⽤纤程就需要通过quasar类库来实现
Java中启动线程的三种方式:
第一种:通过继承Thread类:
通过继承Thread类来创建并启动多线程步骤如下:
1、定义Thread类的子类,重写该类的run()方法,run()方法方法体就表示该线程需要完成的任务,因此,把run()方法称为线程执行体;
2、创建子类线程对象,通过对象调用父类的start()方法启动线程.
创建子类:
public class Thread1 extends Thread{
@Override
public void run() {
for (int i = 0; i < 10; i++) {
System.out.println(Thread.currentThread().getName()+"执行"+i);
}
}
}
创建测试类Main:
public class Main {
public static void main(String[] args) {
new Thread1().start();
for (int i = 0; i < 10; i++) {