Java多线程下解决数据安全问题
目录
- 同步代码块
- 同步方法
- lock锁
同步代码块 基本语句
synchronized (任意对象) {代码示例
操作共享代码
}
public class SellTicket implements Runnable {private int tickets = 100; private Object object = new Object(); @Overridepublic void run() {while (true) {synchronized (object) {if (tickets > 0) {try {Thread.sleep(100); } catch (InterruptedException e) {e.printStackTrace(); }System.out.println(Thread.currentThread().getName() + "正在出售第" + tickets + "张票"); tickets--; }}}}public static void main(String[] args) {SellTicket sellTicket = new SellTicket(); Thread thread1 = new Thread(sellTicket, "窗口1"); Thread thread2 = new Thread(sellTicket, "窗口2"); Thread thread3 = new Thread(sellTicket, "窗口3"); thread1.start(); thread2.start(); thread3.start(); }}
优缺点:
- 解决了多线程的数据安全问题
- 多线程时,每个线程都会判断同步上的锁,耗费资源,降低了程序的运行效率
同步方法 同步方法:将synchronized关键字加到方法上
- 格式: 修饰符 synchronized 返回值类型 方法名(){ }
- 同步方法的锁对象是this
- 格式: 修饰符 static synchronized 返回值类型 方法名(){ }
- 同步静态方法的锁对象是 类名.class
public class SellTicket implements Runnable {//private int tickets = 100; private static int tickets = 100; private Object object = new Object(); private int x = 0; @Overridepublic void run() {while (true) {if (x % 2 == 0) {//synchronized (object) {//synchronized (this) {synchronized (SellTicket.class) {if (tickets > 0) {try {Thread.sleep(100); } catch (InterruptedException e) {e.printStackTrace(); }System.out.println(Thread.currentThread().getName() + "正在出售第" + tickets + "张票"); tickets--; }}} else {//synchronized (object) {//if (tickets > 0) {//try {//Thread.sleep(100); //} catch (InterruptedException e) {//e.printStackTrace(); //}//System.out.println(Thread.currentThread().getName() + "正在出售第" + tickets + "张票"); //tickets--; //}//}sellTicket(); }x++; }}//private void sellTicket(){//synchronized (object) {//if (tickets > 0) {//try {//Thread.sleep(100); //} catch (InterruptedException e) {//e.printStackTrace(); //}//System.out.println(Thread.currentThread().getName() + "正在出售第" + tickets + "张票"); //tickets--; //}//}//}//private synchronized void sellTicket(){//if (tickets > 0) {//try {//Thread.sleep(100); //} catch (InterruptedException e) {//e.printStackTrace(); //}//System.out.println(Thread.currentThread().getName() + "正在出售第" + tickets + "张票"); //tickets--; //}private static synchronized void sellTicket(){if (tickets > 0) {try {Thread.sleep(100); } catch (InterruptedException e) {e.printStackTrace(); }System.out.println(Thread.currentThread().getName() + "正在出售第" + tickets + "张票"); tickets--; }}public static void main(String[] args) {SellTicket sellTicket = new SellTicket(); Thread thread1 = new Thread(sellTicket, "窗口1"); Thread thread2 = new Thread(sellTicket, "窗口2"); Thread thread3 = new Thread(sellTicket, "窗口3"); thread1.start(); thread2.start(); thread3.start(); }}
lock锁 lock实现提供比使用synchronized方法和语句可获得更广泛的操作
- void lock()获得锁
- void unlock()释放
import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; public class SellTicket implements Runnable {private int tickets = 100; private Object object = new Object(); private Lock lock = new ReentrantLock(); @Overridepublic void run() {while (true) {try {lock.lock(); if (tickets > 0) {try {Thread.sleep(100); } catch (InterruptedException e) {e.printStackTrace(); }System.out.println(Thread.currentThread().getName() + "正在出售第" + tickets + "张票"); tickets--; }} finally {lock.unlock(); }}}public static void main(String[] args) {SellTicket sellTicket = new SellTicket(); Thread thread1 = new Thread(sellTicket, "窗口1"); Thread thread2 = new Thread(sellTicket, "窗口2"); Thread thread3 = new Thread(sellTicket, "窗口3"); thread1.start(); thread2.start(); thread3.start(); }
【Java多线程下解决数据安全问题】到此这篇关于Java多线程下解决数据安全问题的文章就介绍到这了,更多相关java多线程数据安全内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- JAVA(抽象类与接口的区别&重载与重写&内存泄漏)
- 放屁有这三个特征的,请注意啦!这说明你的身体毒素太多
- 爱就是希望你好好活着
- 昨夜小楼听风
- 知识
- 死结。
- 我从来不做坏事
- 烦恼和幸福
- 关于QueryWrapper|关于QueryWrapper,实现MybatisPlus多表关联查询方式
- 事件代理