线程小记

来源:互联网 发布:edg网络黄金官方网站 编辑:程序博客网 时间:2024/06/05 20:01
多线程: 一个进程中有多个线程可以同时执行任务。多线程 的好处:1. 解决一个进程中可以同时执行多个任务的问题。2. 提高了资源利用率。

多线程的弊端:
1. 增加了cpu的负担。
2. 降低了一个进程中线程 的执行概率。
3. 出现了线程 安全问题。
4. 会引发死锁现象。
自定义线程 的实现方式
方式一 :
1. 自定义一个类继承Thread类。
2. 重写Thread类的run方法,把自定义线程的任务代码写在run方法上。
3. 创建Thread的子类对象,并且调用start方法启动一个线程。
方式二:
1. 自定义一个类实现Runnable接口。
2. 实现Runnable接口 的run方法,把自定义线程的任务定义在run方法上。
3. 创建Runnable实现类对象。
4. 创建Thread类 的对象,并且把Runnable实现类的对象作为实参传递。
5. 调用Thread对象 的start方法开启一个线程。
推荐使用: 第二种。 实现Runable接口的。
原因: 因为java单继承 ,多实现的。
2.2 线程的状态
创建:新创建了一个线程对象。
可运行:线程对象创建后,其他线程调用了该对象的start()方法。该状态的线程位于可运行线程池中,变得可运行,等待获取cpu的执行权。
运行:就绪状态的线程获取了CPU执行权,执行程序代码。
阻临时塞: 阻塞状态是线程因为某种原因放弃CPU使用权,暂时停止运行。直到线程进入就绪状态,才有机会转到运行状态。
死亡:线程执行完它的任务时。

线程安全问题:线程安全出现 的根本原因:    1. 存在两个或者两个以上 的线程对象共享同一个资源。    2. 多线程操作共享资源的代码 有多句。    线程安全问题的解决方案:方式一: 可以使用同步代码块去解决。    格式:    synchronized(锁对象){        需要被同步的代码    }

同步代码块要注意的事项:
1. 锁对象可以是任意的一个对象。
2. 一个线程在同步代码块中sleep了,并不会释放锁对象。
3. 如果不存在着线程安全问题,千万不要使用同步代码块,因为会降低效率。
4. 锁对象必须是多线程共享的一个资源,否则锁不住。
方式二:同步函数 : 同步函数就是使用synchronized修饰一个函数。

同步函数要注意的事项 :    1. 如果是一个非静态的同步函数的锁 对象是this对象,如果是静态的同步函数的锁 对象是当前函数所属的类的字节码文件(class对象)。    2. 同步函数的锁对象是固定的,不能由你来指定 的。推荐使用: 同步代码块。

锁对象
Java中的每个对象都有一个内置锁,只有当对象具有同步方法代码时,内置锁才会起作用,当进入一个同步的非静态方法时,就会自动获得与类的当前实例(this)相关的锁,该类的代码就是正在执行的代码。
获得一个对象的锁也成为获取锁、锁定对象也可以称之为监视器来指我们正在获取的锁对象。
因为一个对象只有一个锁,所有如果一个线程获得了这个锁,其他线程就不能获得了,直到这个线程释放(或者返回)锁。
也就是说在锁释放之前,任何其他线程都不能进入同步代码(不可以进入该对象的任何同步方法)。
释放锁指的是持有该锁的线程退出同步方法,此时,其他线程可以进入该对象上的同步方法。

死锁现象出现 的根本原因:1. 存在两个或者两个以上的线程。2. 存在两个或者两个以上的共享资源。死锁现象的解决方案: 只能尽量避免发生而已。

线程通讯: 一个线程完成了自己的任务时,要通知另外一个线程去完成另外一个任务.
wait(): 等待 如果线程执行了wait方法,那么该线程会进入等待的状态,等待状态下的线程必须要被其他线程调用notify方法才能唤醒。
notify(): 唤醒 唤醒线程池等待线程其中的一个。
notifyAll() : 唤醒线程池所有等待 线程。

wait与notify方法要注意的事项:
1. wait方法与notify方法是属于Object对象 的。
2. wait方法与notify方法必须要在同步代码块或者是同步函数中才能 使用。
3. wait方法与notify方法必需要由锁对象调用。
线程的停止:
1. 正常终止 当线程的run()执行完毕,线程死亡。
2. 使用标记停止线程
注意:Stop方法已过时,就不能再使用这个方法。
如何使用标记停止线程停止线程。
开启多线程运行,运行代码通常是循环结构,只要控制住循环,就可以让run方法结束,
1. 停止一个线程 我们一般都会通过一个变量去控制的。
2. 如果需要停止一个处于等待状态下的线程,那么我们需要通过变量配合notify方法或者interrupt()来使用。
interrupt()把线程的等待状态强制清除,被清除状态的线程会接收到一个InterruptedException。
守护线程(后台线程):在一个进程中如果只剩下 了守护线程,那么守护线程也会死亡。
d.setDaemon(true); //setDaemon() 设置线程是否为守护线程,true为守护线程, false为非守护线程。
// System.out.println(“是守护线程吗?”+ d.isDaemon()); //判断线程是否为守护线程。
常用方法
Thread(String name) 初始化线程的名字
getName() 返回线程的名字
setName(String name) 设置线程对象名
sleep() 线程睡眠指定的毫秒数。
getPriority() 返回当前线程对象的优先级 默认线程的优先级是5
setPriority(int newPriority) 设置线程的优先级 虽然设置了线程的优先级,但是具体的实现取决于底层的操作系统的实现(最大的优先级是10 ,最小的1 , 默认是5)。
currentThread() 返回CPU正在执行的线程的对象

原创粉丝点击