多线程编程-synchronized
使用取钱的demo来模拟实现线程的同步
package com.iotec.synchronizedTest;
import java.io.ObjectInputStream;
public class BankDemo {
public static void main(String[] args) {
Bank bank = new Bank();
BankThread p1 = new BankThread(bank);
p1.start(); //柜台取钱
BankThread p2 = new BankThread(bank);
p2.start(); //ATM机上取钱
}
}
class BankThread extends Thread{
private Bank bank = null;
public BankThread(Bank bank){
this.bank = bank;
}
@Override
public void run() {
System.out.println(Thread.currentThread().getName()+"取钱:"+bank.getMoney(400));
}
}
class Bank {
//把竞争访问的资源标识为private
private int money = 500;
private Object object = new Object();
//取钱的方法,返回取钱的数目
//当一个线程去调用同步方法的时候,这个线程就获得当前对象的锁
//其它线程当调用同步方法的时候只能等待,因为无法获取对象的锁
//只有第一个线程释放对象的锁方可进入
/* public synchronized int getMoney(int number){
if(number<0){
return -1;
}else if(money<0){
return -2;
}else if(number-money>0){
return -3;
}else {
try {
Thread.sleep(1000); //模拟取钱的时间
} catch (InterruptedException e) {
e.printStackTrace();
}
money -= number;
System.out.println("余额:"+money);
}
return number;
}*/
public synchronized int getMoney(int number){
// synchronized (this){
//可以持有的是任何对象
synchronized (object){
if(number<0){
return -1;
}else if(money<0){
return -2;
}else if(number-money>0){
return -3;
}else {
try {
Thread.sleep(1000); //模拟取钱的时间
} catch (InterruptedException e) {
e.printStackTrace();
}
money -= number;
System.out.println("余额:"+money);
}
return number;
}
}
/* public synchronized int getMoney(int number){
if(number<0){
return -1;
}else if(money<0){
return -2;
}else if(number-money>0){
return -3;
}else {
//放在这里是不对的,因为等第一个线程执行完,第二个线程对上面的逻辑并不会进行判断
//所以需要考虑清楚需要同步的是哪一个代码块
synchronized (this){
try {
Thread.sleep(1000); //模拟取钱的时间
} catch (InterruptedException e) {
e.printStackTrace();
}
money -= number;
System.out.println("余额:"+money);
}
}
return number;
}*/
}
使用printChar来模拟线程的同步
Object obj = new Object();
new Thread() {
@Override
public void run() {
synchronized (obj) {
for (int i = 1; i <= 100; i++) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("B");
if (i % 4 == 0) {
try {
obj.wait();//释放锁
obj.notify();//唤醒打印AAAAA 的线程
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
}
}.start(); new Thread() {
@Override
public void run() {
synchronized (obj) {
for (int i = 1; i <= 100; i++) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("AAAAA");
try {
obj.notify();//唤醒打印B的线程
obj.wait();//释放锁
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
}.start();
使用另一个demo来模拟线程的死锁
package com.iotec.synchronizedTest;
public class DieThreadDemo {
public static void main(String[] args) {
Example example = new Example();
DieThread1 dieThread1 = new DieThread1(example);
dieThread1.start();
DieThread2 dieThread2 = new DieThread2(example);
dieThread2.start();
}
}
class DieThread1 extends Thread{
private Example example = null;
public DieThread1(Example example){
this.example = example;
}
@Override
public void run() {
example.method1();
}
}
class DieThread2 extends Thread{
private Example example = null;
public DieThread2(Example example){
this.example = example;
}
@Override
public void run() {
example.method2();
}
}
class Example{
private Object obj1 = new Object();
private Object obj2 = new Object();
public void method1(){
synchronized (obj1){
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (obj2){
System.out.println("method1");
}
}
}
public void method2(){
synchronized (obj2){
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (obj1){
System.out.println("method2s");
}
}
}
}
多线程编程-synchronized的更多相关文章
- Java多线程编程(四)—浅谈synchronized与lock
一.共享资源竞争问题 在Java语言的并发编程中,由于我们不知道线程实际上在何时运行,所以在实际多线程编程中,如果两个线程访问相同的资源,那么由于线程运行的不确定性便会在这种多线程中产生访问错误.所以 ...
- Java多线程编程核心技术---学习分享
继承Thread类实现多线程 public class MyThread extends Thread { @Override public void run() { super.run(); Sys ...
- Java—多线程编程
一个多线程程序包含两个或多个能并发运行的部分.程序的每一部分都称作一个线程,并且每个线程定义了一个独立的执行路径. 进程:一个进程包括由操作系统分配的内存空间,包含一个或多个线程.一个线程不能独立的存 ...
- .NET面试题解析(07)-多线程编程与线程同步
系列文章目录地址: .NET面试题解析(00)-开篇来谈谈面试 & 系列文章索引 关于线程的知识点其实是很多的,比如多线程编程.线程上下文.异步编程.线程同步构造.GUI的跨线程访问等等, ...
- Java基础复习笔记系列 八 多线程编程
Java基础复习笔记系列之 多线程编程 参考地址: http://blog.csdn.net/xuweilinjijis/article/details/8878649 今天的故事,让我们从上面这个图 ...
- Java多线程编程核心技术---对象及变量的并发访问(二)
数据类型String的常量池特性 在JVM中具有String常量池缓存的功能. public class Service { public static void print(String str){ ...
- Java多线程编程核心技术---Java多线程技能
基本概念 进程是操作系统结构的基础,是一次程序的执行,是一个程序及其数据结构在处理机上顺序执行时所发生的活动,是程序在一个数据集合上运行的过程,是系统进行资源分配和调度的独立单位.线程可以理解成是在进 ...
- Java多线程编程——进阶篇二
一.线程的交互 a.线程交互的基础知识 线程交互知识点需要从java.lang.Object的类的三个方法来学习: void notify() 唤醒在此对象监视器上等待的单个 ...
- .NET面试题解析(07)-多线程编程与线程同步 (转)
http://www.cnblogs.com/anding/p/5301754.html 系列文章目录地址: .NET面试题解析(00)-开篇来谈谈面试 & 系列文章索引 关于线程的知识点其实 ...
随机推荐
- android_layout_relativelayout(二)
官网上的一个xml文件: <?xml version="1.0" encoding="utf-8"?><RelativeLayout xmln ...
- Mysql常用语法及入门开篇(一)
数据:信息,记录.阅读: 数据库:数据的仓库,存储许多的数据(信息).按照数据结构来组件.存储和管理数据的,建立在计算机存储设备上的仓库. DBMS: database management Sy ...
- 个人永久性免费-Excel催化剂功能第75波-标签式报表转标准数据源
数据处理永远是数据分析工作中重中之重的任务,大部分人深深地陷入在数据处理的泥潭中,今天Excel催化剂再接再厉,在过往已提供了主从结构报表数据源的数据转换后,再次给大家送上标签式报表数据源的数据转换操 ...
- springboot4自动配置的原理(浅层)
自动配置的原理(浅层) @Configuration //这是一个配置类 @EnableConfigurationProperties(HttpProperties.class)//启用Configu ...
- fjnu2016-2017 低程 PROBLEM B 捧杯
#include <iostream>#include <cmath>using namespace std; int _gcd(int x,int y){ return y= ...
- 【Java高级】(一)JVM
5.2.1.在Java中如何判断对象已死? 引用计数算法 给对象中添加一个引用计数器,每当有一个地方引用它时,计数器值就加一1:当引用失效时,计数器值就减1:任何时刻计数器为0的对象就是不可能被使用的 ...
- 287. 寻找重复数 Java解法
287. 寻找重复数 这题的难点就在于下面的说明了,我们先不管下面的那些说明的要求,用常规的解法来解答下上的题目. 排序思想解法 先把原来的数组进行排序,然后逐个遍历,一旦发现后一个元素和当前的元素相 ...
- PHP与ECMAScript_4_常用数学相关函数
PHP ECMAScript 向上取整 ceil($number) Math.ceil( number ) 向下取整 floor($number) Math.floor( number ) 绝对值 a ...
- java反射原理及Class应用
反射:框架设计灵魂 框架:半成品软件,可以在框架基础上进行软件开发,简化编码 反射:将类的各个组成部分封装我其他对象,这就是反射机制 好处: 1.可以在程序运行过程中,操作这些对象 2.可以解耦, ...
- 主机cpu突然飙高,如何快速排查问题
[问题发现] 使用zabbix软件监控服务器时发现cpu突然异常,在业务主机上使用top命令查看系统的整体运行情况,使用top命令后发现mysqld占用CPU特别高,初步判断可能是mysqld出现问题 ...