java基础常见问题解析(六) 线程+并发机制

java线程+并发机制

  1. 有关线程的哪些叙述是对的
    a. 一旦一个线程被创建,它就立即开始运行(需要等待CPU调度)
    b. 当一个线程因为抢先机制而停止运行,它被放在可运行队列的前面
    c. 一个线程可能因为不同的原因停止(cease)并进入就绪状态(时间片已到)
    d. 使用start()方法可以使一个线程成为可运行的,但是它不一定立即开始运行

线程的状态

线程有五个状态:
创建状态:线程被创建
就绪状态:线程一旦被创建,等待CPU的调用—形成就绪队列
运行状态:就绪状态的线程被CPU选中被执行,当时间片轮转调度到期后 线程由运行状态进行就绪状态
等待状态:线程运行过过程中由于缺少资源或者其他原因将中途被迫退出 ,即进入等待状态。当满足资源条件的时候,线程由等待状态进行就绪状态,重新等待CPU的调度(就绪状态不能回到等待状态)
结束状态:线程正常执行完毕,进入结束状态(等待状态可以直接进入结束状态 如果发生死锁,计算机不加与干预,系统根据策略将等待状态的进程直接转到结束状态 —非正常结束)

这里写图片描述

start和run的区别

class MyThead extends Thread {

    @Override
    public void run() {
        System.out.println("当前线程的名称为:" + Thread.currentThread().getName());
    }
}

public class ThreadDemo {

    public static void main(String[] args) {
        System.out.println("运行main方法的线程名称为:" + Thread.currentThread().getName() );
        MyThead my1=new MyThead();
        MyThead my2=new MyThead();
//      my1.run();//main 线程就是main  run方法不是真正的调用线程
//      my2.run();//main 线程就是main
        // 线程已经就绪完毕,随时可以执行,但是是否被cpu选中还需要看线程的队列(考虑策略和权重)
        my1.start();//Thread-0
        my2.start();//Thread-1
    }
}

java并发机制

  1. Java 语言中,负责并发管理的机制是
    a. 垃圾回收机制(防止内存泄漏,但不能避免)
    b. 虚拟机机制(实际上是帮助我们实现java跨平台机制)
    c. 代码安全性检查机制(运行时机制,保证代码具有安全性,java虚拟机在执行class文件要进行安全性检查)
    d. 多线程

代码安全性检查机制 三个环节
java转成class文件在运行class文件之前三步操作
1.通过类加载器ClassLoader把class文件加载到JVM(运行的java虚拟机)
2.通过字节码校验器 校验class文件是否有潜在的安全性漏洞(比如内存泄漏,try catch捕获)
3.运行java解析器 解析class文件

*java垃圾回收机制
Object finalize()方法 来实现 —-主要负责垃圾回收
主要功能用子类来实现

方法介绍:
Called by the garbage collector on an object when garbage collection determines that there are no more references to the object. A subclass overrides the finalize method to dispose of system resources or to perform other cleanup.

class Demo {
    @Override
    protected void finalize() throws Throwable {
        // 此方法被调用说明,调用当前方法的对象会被回收
        System.out.println("finalizer方法被调用,调用当前方法的线程为:"
                + Thread.currentThread().getName());
    }
}

public class GCDemo {
    public static void main(String[] args) {
        Demo demo=new Demo();//该对象不会被回收
        // 没有变量引用,则说明该对象是垃圾,默认情况垃圾回收器不会立即回收,这取决于内存是否充足
        new Demo();//需要多测试几次
        // 可以手动调用垃圾回收器线程,回收垃圾对象
        System.gc();//输出Finalizer 垃圾回收线程号
        throw new RuntimeException();//在抛错的情况下不影响垃圾回收线程的执行 说明垃圾回收线程 和 主线程main 是并列的 互不影响的
    }
}

猜你喜欢

转载自blog.csdn.net/qq_19704045/article/details/80295388