JAVA并发学习随笔(1)

简介:
  • 什么是线程,什么是进程?

    根据定义,多任务是当多个进程共享,如CPU处理公共资源。 多线程将多任务的概念扩展到可以将单个应用程序中的特定操作细分为单个线程的应用程序。每个线程可以并行运行。所以一个进程中可以有多个线程。
    
  • 线程的生命周期(有时候说线程的状态)?一般说5个
    新线程(New) - 新线程在新的状态下开始其生命周期。直到程序启动线程为止,它保持在这种状态。它也被称为出生线程。

可运行(Runnable) - 新诞生的线程启动后,该线程可以运行。状态的线程被认为正在执行其任务。
等待(Waiting) - 有时,线程会转换到等待状态,而线程等待另一个线程执行任务。 只有当另一个线程发信号通知等待线程才能继续执行时,线程才转回到可运行状态。
定时等待(Timed Waiting) - 可运行的线程可以在指定的时间间隔内进入定时等待状态。 当该时间间隔到期或发生等待的事件时,此状态的线程将转换回可运行状态。
终止(Dead) - 可执行线程在完成任务或以其他方式终止时进入终止状态。

  • 线程优先级

     每个Java线程都有一个优先级,可以帮助操作系统确定安排线程的顺序。Java线程优先级在MIN_PRIORITY(常数为1)和MAX_PRIORITY(常数为10)之间的范围内。 默认情况下,每个线程都被赋予优先级NORM_PRIORITY(常数为5)。
     然而优先并不能真正意义上保证线程的执行顺序,所以并没有什么用?解释一个,比如yield()方法,会退出当前的线程,让步给其它线程,但是有可能CPU又进来了,还是执行它
    
  • java实现多线程的两种方法(据说有第三种,callable接口+线程池的方法,有兴趣的可以自行问度娘)

有一个点一定要注意,java启动线程一定是start()方法而不是run方 法,之前面试遇到过吭,连面试官都忘记了这种基础问题,run()方法是不是可以执行?答案当然是肯定的,但是执行run方法起始就相当于执行普通的方法。

实现Runnable接口,直接上实列

  class RunnableDemo implements Runnable {
  private Thread t;
  private String threadName;

  RunnableDemo( String name) {
  threadName = name;
  System.out.println("Creating " +  threadName );
  }

  public void run() {
  System.out.println("Running " +  threadName );
  try {
     for(int i = 4; i > 0; i--) {
        System.out.println("Thread: " + threadName + ", " + i);
        // Let the thread sleep for a while.
        Thread.sleep(50);
     }
  }catch (InterruptedException e) {
     System.out.println("Thread " +  threadName + " interrupted.");
  }
  System.out.println("Thread " +  threadName + " exiting.");
  }

  public void start () {
  System.out.println("Starting " +  threadName );
  if (t == null) {
     t = new Thread (this, threadName);
     t.start ();
  }
  }
  }

  public class TestThread {

  public static void main(String args[]) {
  RunnableDemo R1 = new RunnableDemo( "Thread-1");
  R1.start();

  RunnableDemo R2 = new RunnableDemo( "Thread-2");
  R2.start();
  }   
  }

继承Thread类

    class ThreadDemo extends Thread {
   private Thread t;
   private String threadName;

 ThreadDemo( String name) {
  threadName = name;
  System.out.println("Creating " +  threadName );
 }

 public void run() {
  System.out.println("Running " +  threadName );
  try {
     for(int i = 4; i > 0; i--) {
        System.out.println("Thread: " + threadName + ", " + i);
        // Let the thread sleep for a while.
        Thread.sleep(50);
     }
  }catch (InterruptedException e) {
     System.out.println("Thread " +  threadName + " interrupted.");
  }
  System.out.println("Thread " +  threadName + " exiting.");
 }

 public void start () {
  System.out.println("Starting " +  threadName );
  if (t == null) {
     t = new Thread (this, threadName);
     t.start ();
  }
 }
}

public class TestThread {

 public static void main(String args[]) {
  ThreadDemo T1 = new ThreadDemo( "Thread-1");
  T1.start();

  ThreadDemo T2 = new ThreadDemo( "Thread-2");
  T2.start();
 }   
}
  • Java并发常用的方法:
    sleep():线程休眠,不会释放锁,单位ms。

wait():线程等待,会释放同步锁。
notify():唤醒指定的线程,继续执行。
notifyAll():唤醒所有的线程,继续执行。
stop():直接停止线程。
isAlive():测试线程是否处于活动状态。
yield():暂停当前正在执行的线程对象,并执行其他线程。
(其它的看API 主要这些,面试问的最多的sleep和wait有什么区别?)

(未完待续Ing)

相关文章
|
3月前
|
XML Java 编译器
Java学习十六—掌握注解:让编程更简单
Java 注解(Annotation)是一种特殊的语法结构,可以在代码中嵌入元数据。它们不直接影响代码的运行,但可以通过工具和框架提供额外的信息,帮助在编译、部署或运行时进行处理。
111 43
Java学习十六—掌握注解:让编程更简单
|
2月前
|
存储 安全 Java
Java多线程编程中的并发容器:深入解析与实战应用####
在本文中,我们将探讨Java多线程编程中的一个核心话题——并发容器。不同于传统单一线程环境下的数据结构,并发容器专为多线程场景设计,确保数据访问的线程安全性和高效性。我们将从基础概念出发,逐步深入到`java.util.concurrent`包下的核心并发容器实现,如`ConcurrentHashMap`、`CopyOnWriteArrayList`以及`BlockingQueue`等,通过实例代码演示其使用方法,并分析它们背后的设计原理与适用场景。无论你是Java并发编程的初学者还是希望深化理解的开发者,本文都将为你提供有价值的见解与实践指导。 --- ####
|
2月前
|
存储 设计模式 分布式计算
Java中的多线程编程:并发与并行的深度解析####
在当今软件开发领域,多线程编程已成为提升应用性能、响应速度及资源利用率的关键手段之一。本文将深入探讨Java平台上的多线程机制,从基础概念到高级应用,全面解析并发与并行编程的核心理念、实现方式及其在实际项目中的应用策略。不同于常规摘要的简洁概述,本文旨在通过详尽的技术剖析,为读者构建一个系统化的多线程知识框架,辅以生动实例,让抽象概念具体化,复杂问题简单化。 ####
|
3月前
|
存储 SQL 小程序
JVM知识体系学习五:Java Runtime Data Area and JVM Instruction (java运行时数据区域和java指令(大约200多条,这里就将一些简单的指令和学习))
这篇文章详细介绍了Java虚拟机(JVM)的运行时数据区域和JVM指令集,包括程序计数器、虚拟机栈、本地方法栈、直接内存、方法区和堆,以及栈帧的组成部分和执行流程。
52 2
JVM知识体系学习五:Java Runtime Data Area and JVM Instruction (java运行时数据区域和java指令(大约200多条,这里就将一些简单的指令和学习))
|
2月前
|
Java 大数据 API
14天Java基础学习——第1天:Java入门和环境搭建
本文介绍了Java的基础知识,包括Java的简介、历史和应用领域。详细讲解了如何安装JDK并配置环境变量,以及如何使用IntelliJ IDEA创建和运行Java项目。通过示例代码“HelloWorld.java”,展示了从编写到运行的全过程。适合初学者快速入门Java编程。
|
2月前
|
Java 数据库连接 数据库
如何构建高效稳定的Java数据库连接池,涵盖连接池配置、并发控制和异常处理等方面
本文介绍了如何构建高效稳定的Java数据库连接池,涵盖连接池配置、并发控制和异常处理等方面。通过合理配置初始连接数、最大连接数和空闲连接超时时间,确保系统性能和稳定性。文章还探讨了同步阻塞、异步回调和信号量等并发控制策略,并提供了异常处理的最佳实践。最后,给出了一个简单的连接池示例代码,并推荐使用成熟的连接池框架(如HikariCP、C3P0)以简化开发。
73 2
|
2月前
|
JavaScript Java 项目管理
Java毕设学习 基于SpringBoot + Vue 的医院管理系统 持续给大家寻找Java毕设学习项目(附源码)
基于SpringBoot + Vue的医院管理系统,涵盖医院、患者、挂号、药物、检查、病床、排班管理和数据分析等功能。开发工具为IDEA和HBuilder X,环境需配置jdk8、Node.js14、MySQL8。文末提供源码下载链接。
|
3月前
|
Java
【编程进阶知识】揭秘Java多线程:并发与顺序编程的奥秘
本文介绍了Java多线程编程的基础,通过对比顺序执行和并发执行的方式,展示了如何使用`run`方法和`start`方法来控制线程的执行模式。文章通过具体示例详细解析了两者的异同及应用场景,帮助读者更好地理解和运用多线程技术。
45 1
|
3月前
|
小程序 Oracle Java
JVM知识体系学习一:JVM了解基础、java编译后class文件的类结构详解,class分析工具 javap 和 jclasslib 的使用
这篇文章是关于JVM基础知识的介绍,包括JVM的跨平台和跨语言特性、Class文件格式的详细解析,以及如何使用javap和jclasslib工具来分析Class文件。
66 0
JVM知识体系学习一:JVM了解基础、java编译后class文件的类结构详解,class分析工具 javap 和 jclasslib 的使用
|
3月前
|
前端开发 Java 应用服务中间件
Javaweb学习
【10月更文挑战第1天】Javaweb学习
42 2