Java 线程
来源:互联网 发布:iis7.5 php 500错误 编辑:程序博客网 时间:2024/05/16 11:36
1:Java有三种线程实现:
继承Thread类;也是实现了Runnable接口,Thread类也是Runnable接口的子类。
实现Runnable接口;是@FunctoinalInterface,函数式接口,只有唯一一个抽象方法。interface的方法默认是public的。不存在默认权限。
实现Callable接口;Callable接口是为了解决Runnable不能有返回值的。
native关键字说明其修饰的方法是一个原生态方法,方法是在用其他语言实现的文件中。Java语言本身不能对操作系统底层进行访问和操作,但是可以通过JNI接口调用其他语言来实现对底层的访问。JNI的实现就是编写native方法。
多线程的每个主题类必须复写run() 方法;
start()通过同步块保护,并判断了线程的状态。该函数调用了一个native 函数start0(),JNI(Java Native Interface)。通过它调用操作系统API。因为线程必须通过JVM由系统分配管理资源。
多线程一定依靠Thread类的start方法。故Runnable的对象必须通过new Thread(Runnable).start();Thread 类有构造函数接受Runnable对象。
Callable接口实现的。FutureTask的构造可以传入Callable对象实现。再通过Thread的start启动。newThread( new FutureTask( new Callable()))).start
2:线程的命名与取得:
线程的名字应该在启动前定义,不应该重命名线程。
A:在通过Thread的构造传入name参数;
B:通过setName设置名字;
C:在run()中通过Thread的静态方法currentThread取得当前Thread对象,再通过getName取得名字;静态方法:因为当前只可能有一个Thread在cpu。
要取得与当前线程有关的内容,必须通过Thread的静态方法currnetThread,再逐渐取得属性。publicstatic Thread currentThread()
一个JVM进程至少打开2个线程:main,gc
3:线程休眠:
sleep() 被中断休眠以后,会抛出异常。
yield()的目的是让相同优先级的线程之间能适当的轮转执行。但是,实际中无法保证yield()达到让步目的,因为让步的线程还有可能被线程调度程序再次选中。不会释放lock标志。
线程的几种状态:
新建:new一个Thread对象或者其子类对象就是创建一个线程;
就绪:新建的对象调用start方法,就开启了线程;
运行:当线程对象获取到了CPU的资源。
冻结:运行过程中的线程由于某些原因(比如wait,sleep),释放了执行资格和执行权。
死亡:当线程对象调用的run方法结束,或者直接调用stop方法。
4:线程优先级:
主线程是中等优先级;
5:线程的同步与死锁:
sleep是线程类(Thread)的方法,导致此线程暂停执行指定时间,把执行机会给其他线程,但是监控状态依然保持,到时后会自动恢复。调用sleep不会释放对象锁。
wait是Object类的方法,对此对象调用wait方法导致本线程放弃对象锁,进入等待此对象的等待锁定池,只有针对此对象发出notify方法(或notifyAll)后本线程才进入对象锁定池准备获得对象锁进入运行状态。
synchronized:可以通过同步代码块以及同步方法使用。
一旦线程拥有了Synchronized对象,就可以多次重入,如递归。
守护线程setDaemon(boolean on)的特点:
守护线程开启后和前台线程共同抢夺cpu的执行权,开启、运行两者都没区别,但结束时有区别,当主线程结束,守护线程会自动结束。
多线程join方法:
特点:当A线程执行到B线程的join方法时,A就会等待B线程都执行完,A才会执行.
Java的每个对象(Object和class)都关联着一个锁(有时也叫“互斥量”),这个锁在操作系统中称为“信号量”,互斥(“mutex“)是一个二进制的信号量(有别于整型信号量)。JAVA每个对象(Object/class)都关联一个监视器,监视器的互斥功能就是依靠锁实现的。
线程的监视器,即线程所持有的锁,也就是synchronized所关联的对象。线程的互斥由线程的监视器机制来实现。
监视器分为对象监视器与线程监视器。
“在JVM中,每个对象和类在逻辑上都是和一个监视器相关联的”
“为了实现监视器的排他性监视能力,JVM为每一个对象和类都关联一个锁”
“锁住了一个对象,就是获得对象相关联的监视器”
synchronized是唯一实现同步的东西。对于下面的java程序:
synchronized(obj)
{
... ...
}
在class中将被翻译成
monitorenter(obj)
...
monitorexit(obj)
如果某个synchronized方法是static的,那么当线程访问该方法时,它锁的并不是synchronized方法所在的对象,而是synchronized方法所在的类所对应的Class对象。Java中,无论一个类有多少个对象,这些对象会对应唯一一个Class对象,因此当线程分别访问同一个类的两个对象的两个static,synchronized方法时,它们的执行顺序也是顺序的,也就是说一个线程先去执行方法,执行完毕后另一个线程才开始。
- Java线程:什么是线程
- Java线程:线程池
- java线程--线程退出
- JAVA-线程/线程锁
- Java线程:什么是线程
- Java线程:线程中断
- Java线程:线程状态
- Java线程: 线程调度
- Java线程:线程交互
- java--线程--线程池
- java 线程
- Java线程
- java线程
- java线程
- Java线程
- Java线程
- java线程
- JAVA 线程
- iOS 字符串筛选手机号
- javaScript调用WordChart控件(C#开发的),js的数据传到C#方法后多了个“空格”
- 用matlab把某文件夹下所有.mp3格式文件转换成.wav
- 浅谈慕课网React入门课程笔记(一)
- 高斯相乘引理及其证明
- Java 线程
- 集合框架
- 内外连接
- java中类的继承
- Java ---多线程3
- 对象和调用方法
- HDU5945 Fxx and game
- 复习
- ViewPager网络请求图片并无限轮播