Java 并行程序基础
来源:互联网 发布:iis php mysql 编辑:程序博客网 时间:2024/05/21 10:07
1.线程中断
主要有三个方法:public void Thread.interrupt() // 中断线程
public boolean Thread.isInterrupted() //判断是否非中断
public static boolean Thread.interrupted() // 判断是否被中断,并清除当前中断状态
Thread.sleep() 函数:让当前线程休眠若干时间,会抛出InteeruptedException中断异常,必须捕获并处理,由中断抛出异常,会清楚中断标志位
2.等待(wait)和通知(notify):当一个线程调用wait()方法后,当前线程就会在这个对象上等待,进入等待队列。当notify()方法被调用,从等待队列随机选择一个线程唤醒,notifyAll()方法唤醒等待队列中所有的线程。必须包含在synchrozied语句中,都需要首先获得目标对象的一个监视器。与sleep()方法主要区别是wait()方法会释放目标对象的锁。
3. volatile() 保证操作的原子性,可见性,有序性。但是无法保证一些复合操作部的原子性
4.synchronized的作用是实现线程的同步,对同步的代码加锁,使每一次只能有一个线程进入同步块,他是不公平的锁。
(1) 指定加锁对象:给对象加锁,进入同步对象之前要获得给定对象的锁。
(2)直接作用于实例方法:进入同步代码前要或的当前实例的锁
(3)直接作用于静态方法:进入同步块前要获得当前类的锁。
5. 同时有几种线程不安全的列表:ArrayList,HashMap等都是线程不安全的。
6.其他的几种同步控制方法:
(1) 重入锁Reentrantlock,可以被中断,锁申请等待限时,公平锁.主要方法:lock():获得锁,如果锁已经被占用,则等待。lockInterruptibly():获得锁,但优先响应中断。tryLock():尝试获得锁,该方法不等待,立即返回。tryLock(long time,TimeUnit unit) 在给定时间内尝试获得锁。unlock():释放锁。
7.提高锁的 性能几种方法:
1.减小锁粒度:缩小锁定对象的范围,从而减小锁冲突的可能
2.减小锁持有的时间
3.读写分离锁来替换独占锁:读多写少可以有效提升性能
4.锁分离
5:锁粗化:在遇到一连串地对锁进行请求和释放的操作时,便把所有的锁操作整合成对锁的一次请求。
6:锁偏向:如果一个线程获得了锁,那马就进入偏向模式,当这个线程子再次请求,无须在做任何同步操作。
8.比较交换(CAS):无锁
- Java并行程序基础
- Java并行程序基础
- java并行程序基础
- Java 并行程序基础
- Java并行程序基础总结
- 第二章 Java并行程序基础
- 《Java高并发程序设计》总结--2.Java并行程序基础
- java高并发程序设计总结二:java并行程序基础
- Java高并发程序设计笔记2之并行程序基础
- Java高并发设计——并行程序基础一
- Java高并发设计——并行程序基础二
- (二)Java 并行程序
- 实战Java高并发程序设计(二)Java并行程序基础
- java基础——串行与并行
- 【Java高并发学习】并行基础概念
- 自动检测并行 Java 程序中的错误
- 关于java并行程序开发重点
- 如何提高Java并行程序性能
- Python字典vs Js对象-动态键
- Mybatis3文档阅读(三)之Mapper XML
- 习题 6.14 编一个程序,将两个字符串s1和s2比较,若s1>s2,输出一个正数;若s1=s2, 输出0;若s1<s2,输出一个负数。不要用strcmp函数。两个字符串用gets函数输入。
- Poj3250 Bad Hair Day (单调栈)
- eclipse最常用的最实用快捷键,修改快捷键
- Java 并行程序基础
- 拦截导弹问题
- react生命周期函数
- 对数据库进行CRUD
- 加载图片错乱
- centoos安装rabbitmq
- PAT 1033. To Fill or Not to Fill
- 跑马灯来回跑
- 【转】C++顺序性容器、关联性容器与容器适配器