Java 之 多线程编程

1.线程:

  a.由来:单任务OS —— 多任务OS

  b.进程:每一个进程对应一个应用程序,分配独立内存空间

  c.线程:线程是进程内部的一个独立的执行分支

  d.特点:共享内容地址空间,切换成本更低

2.线程的创建和启动

  a.方法一:(Thread)

    ①继承Thread类,重写run方法——run方法只负责确定这个线程要做的事情

public class MyThread extends Thread{
    public void run() {

    }
}

    ②开启线程,要调用start方法——该方法会为线程分配资源,然后自动调用this.run()

MyThread mt = new MyThread();
mt.start();        //开启线程

    ③如果调用run方法——不会报错,但只是普通的方法调用,没有开启新线程

  b.方法二:(Runnable)

    ①实现Runnable接口,重写run方法——run方法只负责确定这个线程要做的事情

public class YourThread implements Runnable{
    public void run() {

    }
}

    ②创建一个Thread对象,把Runnable接口的实现类对象传入

     调用Thread对象的start()

YourThread yt = new YourThread();
Thread th = new Thread(yt);
th.start();

3.线程状态

  a.流程:①新建状态(new Thread() 对象)——就绪状态(调用start(),但start()在调用run()之前)——运行状态(start(),调用run())——死亡状态(run()方法结束,进行资源回收清理)

      ②中断状态:在运行状态中,线程由于种种原因没有得到CPU执行

  b.中断状态的五个原因:

    ①线程的优先级:线程优先级共十级,最高为10,最低为1

            优先级高的只是被执行的几率更大,不代表完胜优先级低的

th.setPriority(10);

th.setPriority(Thread.MAX_PRIORITY);

    ②阻塞:由于输入/输出,造成线程进行中断状态(如:Scanner)

    ③休眠:Thread的sleep方法

th.sleep(500);        //传休眠的毫秒数

    ④等待 与 唤醒:Object 的 wait() 与 notify() 方法

    ⑤挂起:Thread 的 yield() 方法

4.同步锁

  a.关键字:synchronized

  b.意义:当多个线程访问同一资源的时候,有可能造成该资源数据混乱。

      为保证该资源每次只能被一个线程使用,使用完以后再交给下一个线程,我们要使用同步技术。

  c.同步的实现:

    ①同步方法:在资源身上加同步关键字synchronized

public synchronized void show(String name){

}

    ②同步块:在调用资源的线程身上使用synchronized

synchronized(this.rs){
        this.rs.show(this.getName());
}

  

时间: 2024-10-25 15:38:01

Java 之 多线程编程的相关文章

Java的多线程编程模型5--从AtomicInteger开始

Java的多线程编程模型5--从AtomicInteger开始 2011-06-23 20:50 11393人阅读 评论(9) 收藏 举报 java多线程编程jniinteger测试 AtomicInteger,一个提供原子操作的Integer的类.在Java语言中,++i和i++操作并不是线程安全的,在使用的时候,不可避免的会用到synchronized关键字.而AtomicInteger则通过一种线程安全的加减操作接口. 来看AtomicInteger提供的接口. //获取当前的值 publ

Java Socket 多线程编程,处理百万级的数据并发。

感谢网上的大神分享的代码,然后我根据我们项目的需求,组装成余下代码,基本上大概的框架就是这个模式,需要修改的就是业务数据的传递 ,其他的都是不用修改的. 本着学习他人代码,学会他人分享精神,因此将我花了两天研究的代码分享出来(晚上的时间).希望有大神多多指教我这个编程菜鸟的技术,本菜鸟感激不敬. ServerSocket : import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.IOExcepti

Java基础知识—多线程编程(五)

概述 Java 给多线程编程提供了内置的支持.一个多线程程序包含两个或多个能并发运行的部分.程序的每一部分都称作一个线程,并且每个线程定义了一个独立的执行路径.使用多线程也是为了充分的利用服务器资源,提高工作效率. 线程生命周期 线程是一个动态执行的过程,它也有一个从产生到死亡的过程. 新建状态: 使用 new 关键字和 Thread 类或其子类建立一个线程对象后,该线程对象就处于新建状态.它保持这个状态直到程序 start() 这个线程. 就绪状态: 当线程对象调用了start()方法之后,该

(1)Java多线程编程核心——Java多线程技能

1.为什么要使用多线程?多线程的优点? 提高CPU的利用率 2.什么是多线程? 3.Java实现多线程编程的两种方式? a.继承Thread类 public class MyThread01 extends Thread {     @Override     public void run() {         super.run();         System.out.println("MyThread01");     } public static void main(S

Java - 32 Java 多线程编程

Java 多线程编程 Java给多线程编程提供了内置的支持.一个多线程程序包含两个或多个能并发运行的部分.程序的每一部分都称作一个线程,并且每个线程定义了一个独立的执行路径. 多线程是多任务的一种特别的形式.多线程比多任务需要更小的开销. 这里定义和线程相关的另一个术语:进程:一个进程包括由操作系统分配的内存空间,包含一个或多个线程.一个线程不能独立的存在,它必须是进程的一部分.一个进程一直运行,直到所有的非守候线程都结束运行后才能结束. 多线程能满足程序员编写非常有效率的程序来达到充分利用CP

Android多线程编程(一)——多线程基础

什么是进程 一个进程是一个独立(self contained)的运行环境,它可以看作一个程序或者一个应用. 什么是线程 而线程是进程中执行的一个任务,Java运行环境是一个包含了不同累和程序的单一进程.线程可以被称为轻量级进程.线程需要较少的资源来创建和驻留在进程中,并且可以共享进程中的资源. Android线程 Android的线程,实际上和Java的多线程编程并没有什么本质上的不同.当我们需要执行一些耗时操作,比如说发起一条网络请求时,考虑到网速等其他原因,服务器未必会立刻响应我们的请求,如

Java的多线程 简单入门

Java的多线程 简单入门 首先可以先搞清楚什么是程序.进程.线程,以及它们之间的关系: 定义: 一 程序只是一组指令的有序集合,它是静态的 二 进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,是系统进行资源分配和调度的一个独立单位: 三 线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),一个线程可以创建和撤销另一个线程: 进程与线程区别与联系 (

Java Thread 多线程 介绍

1.线程概述 几乎所有的操作系统都支持同时运行多个任务,一个任务通常就是一个程序,每个运行中的程序就是一个进程. 当一个程序运行时,内部可能包含了多个顺序执行流,每个顺序执行流就是一个线程. 2.线程和进程 几乎所有的操作系统都有进程的概念,所有运行中的任务通常对应一条进程.当一个程序进入内存运行,就是一个进程了. 进程是处于运行中的程序,具有一定的独立能力,进程是系统进行资源分配和调度的一个独立单位. 进程特征: A.独立性:进程是系统中独立存在的实体,可以拥有自己独立的资源,每个进程都拥有自

20180829-Java多线程编程

Java 多线程编程 Java给多线程编程提供了内置的支持.一个多线程程序包含两个或多个能并发运行的部分. 程序的每一部分都称作一个线程,并且每个线程定义了一个独立的执行路径. 多线程是多任务的一种特别的形式.多线程比多任务需要更小的开销. 这里定义和线程相关的另一个术语: 进程:一个进程包括由操作系统分配的内存空间,包含一个或多个线程.一个线程不能独立的存在,它必须是进程的一部分.一个进程一直运行,直到所有的非守候线程都结束运行后才能结束. 多线程能满足程序员编写非常有效率的程序来达到充分利用