静态代码块中没有this

/*

* 线程安全问题产生的原因:

* 1.多个线程操作共享的数据

* 2.操作共享数据的线程代码有多条

*

* 当一个线程在执行操作共享数据的多条代码过程中,其他线程参与了云轩。就会导致线程安全问题的产生。

* 解决思路:

* 就是将多条操作共享数据的线程代码封装起来,当有线程在执行这些代码的时候,其他线程不可以参与运算的。

* 必须要当前线程把这些代码都执行完成后,其他线程才可以参与运算。

*

* 在java中,用同步代码块就可以解决这个问题。

同步函数使用的锁是this

* 同步代码块的格式:

* synchronized(对象)

* {


需要被同步的 代码块;

* }

同步的好处:解决了线程的安全问题。

* 同步的弊端:相对降低了效率,因为同步外的线程都会判断同步锁。

同步函数使用的锁是this;

同步函数和同步代码块的区别:

同步函数的锁是固有的的this。

同步代码块的锁是任意的对象。

建议使用  同步代码块。

*/

class TicketTest implements Runnable

{

private int num = 100;

private Object obj = new Object();

@Override

public void run()

{

// TODO Auto-generated method stub

while(true)

{

synchronized(obj)

{

if(num>0)

{

System.out.println(Thread.currentThread().getName()+"------------"+num--);

}

else

break;

}

}

}

}

public class Ticket

{

public static void main(String[] args)

{

//创建一个线程任务对象

TicketTest t = new TicketTest();

Thread t1 = new Thread(t);

Thread t2 = new Thread(t);

Thread t3 = new Thread(t);

Thread t4 = new Thread(t);

t1.start();

t2.start();

t3.start();

t4.start();

}

}

l


/*

* 建立一个线程任务:

* 目的是  向银行 每次存款 100,  存3次

同步函数使用的锁是this

*/

class Bkk implements Runnable

{

private Bank b = new Bank();

@Override

public void run()

{

// TODO Auto-generated method stub

for(int i=0; i<3; i++)

{

b.add(100);

}

}

}

class Bank

{

private int sum;

同步函数使用的锁是this

public synchronized void add(int num)//同步函数********************

{

sum += num;

System.out.println(sum);

}

}


================================================================================
死锁问题——

public class LockTest

{

public static void main(String[] args)

{

// TODO Auto-generated method stub

RenWu a = new RenWu(true);

RenWu b = new RenWu(false);

Thread t1 = new Thread(a);

Thread t2 = new Thread(b);

t1.start();

t2.start();

}

}

//任务对象

class RenWu implements Runnable

{

private Boolean flag;//设定俩中情况

RenWu(Boolean flag)

{

this.flag = flag;

}

@Override

public void run()

{

// TODO Auto-generated method stub

if(flag)//让第一种情况去用第一把锁

{

synchronized (MyLock.Locka)

{

System.out.println(Thread.currentThread().getName()+".........."+ MyLock.Locka);

synchronized (MyLock.Lockb)//然后想用另外一把锁   这时发现   另外这把锁  有可能就被  另一个任务线程使用着

{

System.out.println(Thread.currentThread().getName()+".........."+ MyLock.Lockb);

}

}

}

else//让第二种情况去使用  第二把锁

{

synchronized (MyLock.Lockb)

{

System.out.println(Thread.currentThread().getName()+".........."+ MyLock.Lockb);

synchronized (MyLock.Locka)//然后想用另外一把锁   这时发现   另外这把锁  有可能就被  另一个任务线程使用着

{

System.out.println(Thread.currentThread().getName()+".........."+ MyLock.Locka);

}

}

}

}

}

//只有俩把锁    主要有其中一把锁 被锁上了   另外想用这吧锁的  这能等正在用的这把锁被打开后 才能使用

class MyLock

{

final static Object Locka = new Object();

final static Object Lockb = new Object();

}

l



版权声明:本文为博主原创文章,未经博主允许不得转载。

Java——多线程安全问题的更多相关文章

  1. Java 多线程安全问题简单切入详细解析

    线程安全 假如Java程序中有多个线程在同时运行,而这些线程可能会同时运行一部分的代码.如果说该Java程序每次运行的结果和单线程的运行结果是一样的,并且其他的变量值也都是和预期的结果是一样的,那么就 ...

  2. java基础知识回顾之java Thread类学习(四)--java多线程安全问题(锁)

    上一节售票系统中我们发现,打印出了错票,0,-1,出现了多线程安全问题.我们分析为什么会发生多线程安全问题? 看下面线程的主要代码: @Override public void run() { // ...

  3. 【JAVA多线程安全问题解析】

    一.问题的提出 以买票系统为例: class Ticket implements Runnable { public int sum=10; public void run() { while(tru ...

  4. java 多线程安全问题-同步代码块

    /* 多线程的安全问题: while(true) { if(tick>0) { //线程0,1,2,3在余票为1时,都停滞在这里,之后分别获得CPU执行权,打印出0,-1,-2等错票 Syste ...

  5. java多线程安全问题-同步修饰符于函数

    上一篇文章通过卖票使用同步代码块的方法解决安全问题本篇文章首先探讨如何找出这样的安全问题,并提出第二种方式(非静态函数synchronized修饰)解决安全问题 /* 需求: 银行有一个公共账号金库 ...

  6. Java多线程安全问题

    body, table{font-family: 微软雅黑; font-size: 10pt} table{border-collapse: collapse; border: solid gray; ...

  7. java基础知识回顾之java Thread类学习(五)--java多线程安全问题(锁)同步的前提

    这里举个例子讲解,同步synchronized在什么地方加,以及同步的前提: * 1.必须要有两个以上的线程,才需要同步. * 2.必须是多个线程使用同一个锁. * 3.必须保证同步中只能有一个线程在 ...

  8. java 多线程安全问题的解决方法

    三种方法: 同步代码块: synchronized(obj) { //obj表示同步监视器,是同一个同步对象 /**..... TODO SOMETHING */ }   同步方法 格式: 在方法上加 ...

  9. java基础知识回顾之java Thread类学习(七)--java多线程安全问题(死锁)

    死锁:是两个或者两个以上的线程被无限的阻塞,线程之间互相等待所需资源. 线程死锁产生的条件: 当两个线程相互调用Join()方法. 当两个线程使用嵌套的同步代码块的时候,一个线程占用了另一个线程的锁, ...

随机推荐

  1. Matlab:max函数

    Matlab中max函数在矩阵中求函数大小的实例如下: C = max(A)返回一个数组各不同维中的最大元素.如果A是一个向量,max(A)返回A中的最大元素.如果A是一个矩阵,max(A)将A的每一 ...

  2. Python单元测试——unittest

    unittest是python自带的一个模块 python344\Lib\unittest 官方参考文档: http://docs.python.org/2.7/library/unittest.ht ...

  3. httplib、urllib、urllib2的区别

     Python3.4互联网通讯协议支持 1,webbrowser方便的浏览器容器 2,cgi公共网关接口支持 3,cgitb管理cgi脚本 4,wsgiref  WSGI实体和引用实现 5,urlli ...

  4. Navicat提示Access violation at address 004E9844 in module ‘navicat.exe’

    今天在联系MySQL 数据库表的练习时,出现了一下问题: 内存越界问题,最好重新注册下Windows的动态链接库 首先“开始”—“运行”—“cmd” 在打开的dos窗口中运行“for %1 in (% ...

  5. 框架设计——MVC IOC

    主要概念: 注:以下概念是自我理解,不是很准确. IOC:Inversion of Control(控制反转). 本来对象创建是通过使用类内部进行创建,现在把对象创建交给container(容器)管理 ...

  6. hdu 1025 dp 最长上升子序列

    //Accepted 4372 KB 140 ms //dp 最长上升子序列 nlogn #include <cstdio> #include <cstring> #inclu ...

  7. hello world Firmware Library

    其实正点原子有良好的模板工程...user .lab文件 ,obj. 一脸蒙的是库函数的操作方式.... 为了便于管理,该项目文件夹内,我分了以下几个文件夹:"PROJ"存放工程文 ...

  8. 深入分析:Android中app之间的交互(二,使用ComponentName)

    在前一篇相关主题的博文中我们了解了如何使用Action来启动当前应用之外的Activity处理我们的业务逻辑,在本篇笔记中我在简单介绍一下使用ComponentName来与当前应用之外的应用进行交互. ...

  9. C# virtual和abstract的

    virtual和abstract都是用来修饰父类的,通过覆盖父类的定义,让子类重新定义. 它们有一个共同点:如果用来修饰方法,前面必须添加public,要不然就会出现编译错误:虚拟方法或抽象方法是不能 ...

  10. JLOI2010 冠军调查 最小割

    var b,f:..] of longint; s,t,i,j,n,m,x,y:longint; l,h:..]of longint; a:..,..]of longint; procedure bf ...