Synchonized


Java中的每一个对象都可以作为锁.

  1. 对于同步方法,锁是当前实例对象.
  2. 对于静态同步方法,锁是当前对象的Class对象.
  3. 对于同步方法块,锁是Synchonized括号里配置的对象.
/**
 * User: caiyuan
 * Date: 13-1-31
 */
public class SynSelf {

    public void sm1() {
        synchronized (this) {
            while (true) {
                System.out.println("sm1");
                try {
                    Thread.sleep(100);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    }

    public synchronized void sm2() {
        while (true) {
            System.out.println("sm2");
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

    public synchronized void sm3() {
        while (true) {
            System.out.println("sm3");
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

    public static void main(String[] args) {
        final SynSelf syn = new SynSelf();

        new Thread(new Runnable() {
            public void run() {
                syn.sm1();
            }
        }, "sm1").start();

        new Thread(new Runnable() {
            public void run() {
                syn.sm2();
            }
        }, "sm2").start();

        new Thread(new Runnable() {
            public void run() {
                syn.sm3();
            }
        }, "sm3").start();

        System.out.println("start");
    }

}
/**
 * User: caiyuan
 * Date: 13-1-31
 */
public class SynOther {

    public void om1(SynSelf o) {
        synchronized (o) {
            while (true) {
                System.out.println("om1");
                try {
                    Thread.sleep(100);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    }

    public void om2(SynSelf o) {
        synchronized (o) {
            while (true) {
                System.out.println("om2");
                try {
                    Thread.sleep(100);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    }

    public static void main(String[] args) {
        final SynSelf o = new SynSelf();
        final SynOther syn = new SynOther();

        new Thread(new Runnable() {
            public void run() {
                syn.om1(o);
            }
        }, "om1").start();

        new Thread(new Runnable() {
            public void run() {
                syn.om2(o);
            }
        }, "om2").start();

        new Thread(new Runnable() {
            public void run() {
                o.sm1();
            }
        }, "sm1").start();

        new Thread(new Runnable() {
            public void run() {
                o.sm2();
            }
        }, "sm2").start();

        new Thread(new Runnable() {
            public void run() {
                o.sm3();
            }
        }, "sm3").start();

        System.out.println("start");
    }

}
结果:两个测试类都竞争 SynSelf 锁, 执行一个方法体



转载于:https://my.oschina.net/caiyuan/blog/106614

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值