热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

java线程并发机制有关线程的哪些叙述是对的a.一旦一个线程被创建,它就立即开始运行(需要等待CPU调度)b.当一个线程因为抢先机制而停

java线程+并发机制


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

线程的状态

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

这里写图片描述

start和run的区别

class MyThead extends Thread {@Overridepublic 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-0my2.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 {@Overrideprotected 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 是并列的 互不影响的}
}

推荐阅读
author-avatar
J-cha0
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有