java线程基础梳理

java线程

概述
  • 进程:运行时概念,运行的应用程序,进程间不能共享内存
  • 线程:应用程序内并发执行的代码段,可以共享堆内存和方法区内存,而栈内存是独立的。
  • 并发理解:在单核机器上,从微观角度来看,一段时间内cup只能执行一个任务,但是因为cup在只执行一段代码段的时候大部分的时间是处于等待程序的,所以可以再开几条程序,然后通过轮询机制,让cpu执行多个进程,从宏观角度来看就是所谓的并发。如果机器是多核,那么就是真正的并发。
    线程调度模型
  • 线程的调度模型分为: 分时调度模型和抢占式调度模型,Java使用抢占式调度模型
    • 分时调度模型: 所有线程轮流使用CPU的使用权,平均分配每个线程占用CPU的时间片
    • 抢占式调度模型: 优先让优先级高的线程使用CPU,如果线程的优先级相同,那么会随机选择一个,优先级高的线程获取的CPU时间片相对多一些.
  • 线 程 优 先 级 主 要 分 三 种 : MAX_PRIORITY( 最 高 级 );MIN_PRIORITY ( 最 低 级 )NORM_PRIORITY(标准)默认
    java 程序的运行原理?
  • java 命令会启动 java 虚拟机,启动 JVM,等于启动了一个应用程序,表示启动了一个进程。该进程会自动启动一个“主线程”,然后主线程去调用某个类的 main 方法。所以 main方法运行在主线程中。在此之前的所有程序都是单线程的。
  • 一个栈就是一个线程,所谓的并发就是多个不同的栈。
    线程创建
  • 继承Thread
    • 线程编写要继承 java.lang.Thread
    • 重写run方法
    • 调用的时候调用线程类的start()方法,run方法是让cpu调用的。所以start()方法调用后run方法不会立刻调用。
  • 实现runable接口
class CreateRunnable implements Runnable {
    @Override
    publicvoid run() {
        for (inti = 0; i< 10; i++) {
            System.out.println("i:" + i);
        }
    }

}
public class ThreadDemo2 {
    publicstaticvoid main(String[] args) {
        System.out.println("-----多线程创建开始-----");
        // 1.创建一个线程
        CreateRunnable createThread = new CreateRunnable();
        // 2.开始执行线程 注意 开启线程不是调用run方法,而是start方法
        System.out.println("-----多线程创建启动-----");
        Thread thread = new Thread(createThread);
        thread.start();

    }
}
  • 使用匿名内部调用
System.out.println("-----多线程创建开始-----");
         Thread thread = new Thread(new Runnable() {
            public void run() {
                for (int i = 0; i< 10; i++) {
                    System.out.println("i:" + i);
                }
            }
        });
         thread.start();
         System.out.println("-----多线程创建结束-----");
线程分类
  • 主线程、子线程、GC线程

    • 一个进程中肯定要有主线程。一般是用main函数来创建
    • java主线程结束是不影响子线程的。
    • GC线程是守护线程。
    • 守护线程随着主线程的销毁而销毁。
    • 在一个线程start前用thread.setDaemon(true)可以将用户线程变成守护线程。
  • 守护线程和用户线程
    • 从线程分类上可以分为:用户线程(以上讲的都是用户线程),另一个是守护线程。
    • 其它所有的用户线程结束,则守护线程退出!因为 daemon守护线程是守护非守护线程的
    • setDaemon(true) 使线程变成守护线程
    • 守护线程一般都是无限执行的.
    • 例如 java 中著名的垃圾回收器GC线程就是一个守护线程。
线程安全和锁
  • 任何对象都可以是锁,因为锁的本质是参照物,类似于红绿灯,上课铃等等,关键是大家要看一个参照物。
  • 同步代码块(以object为锁)
        synchronized(object){
            [并发逻辑]
        }
  • 加锁里的逻辑要尽量少
  • 同步方法
    public synchronized int getTicket(){

    }
  • 同步方法(非静态)是以当前对象作为锁。

    • 如果用非静态同步方法加锁,一般独立出一个对象池,将同步方法放在对象池内,然后多线程对象每次从同一个对象池取资源。
  • 同步方法(静态) 是以类作为锁。
线程生命周期

  • yield();方法可以让线程方法暂时放弃cpu的抢占,但是一旦放弃后又马上开始抢,有谦让的意义
  • Thread.sleep(time) 静态方法 让当前线程休眠time毫秒,不去抢占cpu
  • join等到指定的线程执行完后执行
    sleep() 与 wait()的比较
  • 相同点:wait()的作用是让当前线程由“运行状态”进入“等待(阻塞)状态”的同时,也会释放同步锁。而sleep()的作用是也是让当前线程由“运行状态”进入到“休眠(阻塞)状态”
  • 不同点:wait()会释放对象的同步锁,而sleep()则不会释放锁
    join()方法作用
  • 当在主线程当中执行到t1.join()方法时,就认为主线程应该把执行权让给t1
    线程死亡
  • 有两个原因会导致线程死亡:

    - 1) run方法正常退出而自然死亡,

    - 2) 一个未捕获的异常终止了run方法而使线程猝死。

    - 为了确定线程在当前是否存活着(就是要么是可运行的,要么是被阻塞了),需要使用isAlive方法。如果是可运行或被阻塞,这个方法返回true; 如果线程仍旧是new状态且不是可运行的, 或者线程死亡了,则返回false.

阻塞状态
  • 线程运行过程中,可能由于各种原因进入阻塞状态:

    • 1>线程通过调用sleep方法进入睡眠状态;
    • 2>线程调用一个在I/O上被阻塞的操作,即该操作在输入输出操作完成之前不会返回到它的调用者;
    • 3>线程试图得到一个锁,而该锁正被其他线程持有;
    • 4>线程在等待某个触发条件;
      参考
  • https://www.cnblogs.com/skywang12345/p/java_threads_category.html

原文地址:https://www.cnblogs.com/frankltf/p/10311848.html

时间: 2024-08-04 08:03:15

java线程基础梳理的相关文章

Java 线程基础

目录 Java 线程基础  一.线程简介  二.线程基本用法  三.线程间通信  四.线程状态  参考资料 Java 线程基础 ?? 本文以及示例源码已归档在 javacore 一.线程简介 什么是进程 什么是线程 进程和线程的区别 二.线程基本用法 创建线程 线程休眠 线程礼让 终止线程 守护线程 FAQ 三.线程间通信 wait/notify/notifyAll join 管道 四.线程状态 参考资料 一.线程简介 什么是进程 简言之,进程可视为一个正在运行的程序.它是系统运行程序的基本单位

并发编程总结——java线程基础1

最近没事,顺便看看java并发编程的东西,然后总结纪录下来,大家如果能看到帮忙指正指正哈哈,另外一方面也为以后自己回顾的时候可以看看. 关于并发编程,准备从几个点切入: 1.java线程几本知识 2.juc原子类 3.锁 4.juc集合 5.线程池 ------------------------------------------------------------------- 分割线开始.... 说到多线程,java中超父类Object中有wait()和notify()方法,包括Runna

Java线程基础知识(状态、共享与协作)

1.基础概念 CPU核心数和线程数的关系 核心数:线程数=1:1 ;使用了超线程技术后---> 1:2 CPU时间片轮转机制 又称RR调度,会导致上下文切换 什么是进程和线程 进程:程序运行资源分配的最小单位,进程内部有多个线程,会共享这个进程的资源 线程:CPU调度的最小单位,必须依赖进程而存在. 澄清并行和并发 并行:同一时刻,可以同时处理事情的能力 并发:与单位时间相关,在单位时间内可以处理事情的能力 高并发编程的意义.好处和注意事项 好处:充分利用cpu的资源.加快用户响应的时间,程序模

Java线程基础

一个线程运行一个顺序程序. 在java中,线程一般是java.lang.Thread的子类,它提供了一些方法来创建线程.启动线程. 挂起线程.等待线程完毕. 首先,创建一个实现Runnable接口的类,该类的run()方法完毕全部的工作.比如.以下是一个打印字符串的简单线程. package lou.thread; public class HelloWorld implements Runnable { String message; public HelloWorld(String m) {

JAVA线程----基础

线程简介: 现在个人计算机操作系统多采用多任务和分时设计.一般可以在 同一时间内执行多个程序的操作系统都有进程的概念.一个进程就是一个执行中的程序,而每一个进程都哟自己独立的一块内存空间.一组系统资源.在进程概念中,每一个进程的内部数据和状态都是完全独立的.Java程序通过流控制来执行程序流,程序中单个顺序流控制称为线程:多线程则是指单个程序中可以同时运行多个不同的线程,执行不同的任务.多线程意味着一个程序的多行语句几乎可以在同一时间内运行的. 线程与进程相似,是一段完成某个特定功能的代码,是程

java 线程基础学习

今天趁空闲时间看了点线程方面的知识 首先看的是volatile关键字,按照我之前书上看到的一点知识,自己的理解是,volatile关键字会阻止编译优化,因为cpu每次读取数据是并不是从高速缓存中读取,而是取内存中的数据.这是自己的一点简单的理解,可能有错误.我之前只是看了点线程方面的知识,只是在自己写代码的时候很少(根本没用到),就是自己学习的时候跟着书上敲了代码. 实习的时候要我写个压力测试,1000个线程同时发请求,统计请求失败的次数,我用了volatile关键字,但是感觉有点问题,今天就测

【Java并发专题之二】Java线程基础

使用线程更好的提高资源利用率,但也会带来上下文切换的消耗,频繁的内核态和用户态的切换消耗,如果代码设计不好,可能弊大于利. 一.线程 进程是分配资源的最小单位,线程是程序执行的最小单位:线程是依附于进程的,一个进程可以生成多个线程,这些线程拥有共享的进程资源: 二.线程生命周期(相关API)1.5个阶段6种状态 5个阶段:新建(New).就绪(Runnable).运行(Running).阻塞(Blocked)和死亡(Dead). 6种状态: public enum State { /** * T

JAVA 线程基础(上)

1.进程是操作系统的一个任务是一块包含了某些资源的内存区域操作系统利用进程把它的工作划分为一些功能单元 进程中所包含的一个或多个执行单元称为线程 2.一个进程至少一个线程,线程通常用于在一个程序中需要同时完成多个任务 3.多个线程同时运行只是我们感官上的一种表现,线程是以并发运行的 并发顾名思义就是线程在计算机cpu上运行的时间片段 微观上走走停停宏观上都在运行 这种现象就是并发 //创建线程1 public class textThread extends Thread{ public voi

JAVA线程基础(下)

前面说了如何建立线程 现在我们来看下线程如何工作的 示例: private ServerSocket server; //保存所有客户端输出流的集合 private List<printwriter> allOut;public Server(){ //创建ServerSocket的同时学要申请服务端口这个端口不能与其他使用TCP协议应用程序冲突 否则会抛出异常 server = new ServerSocket(8088); //申请8088端口 allOut = new ArrayLIST