java 并发编程【一个demo 学习--thread(一)】

多线程实现方式有两种,第一个是 继承 Thread,或者继承 Runable 接口

 

package com.study.thread;

public class ThreadTest extends Thread{

    private int count=5;

    @Override
    public void run() {
        count --;
        System.out.println(Thread.currentThread().getName() + " count " + this.count);
    }

    public static void main(String[] args) {
        /**
         * 分析 当多线程访问 mythread run 方法时,  已排队的方式执行处理(这里排队时按住 cpu 分配顺序执行的)
         */
        ThreadTest threadTest = new ThreadTest();
        Thread t1 = new Thread(threadTest,"test1");
        Thread t2 = new Thread(threadTest,"test2");
        Thread t3 = new Thread(threadTest,"test3");
        Thread t4 = new Thread(threadTest,"test4");
        Thread t5 = new Thread(threadTest,"test5");
        t1.start();
        t2.start();
        t3.start();
        t4.start();
        t5.start();
    }
}

 

打印结果如下:

多线程访问公众资源变量的时候,是不安全的,可以通过 

synchronized  来进行处理

可以看到 数据正常输出,当时请注意 线程不是 按照  test1  test2 test3 test4 test5 输出的,这里执行顺序 并不是我们代码的顺序,而是 通过 cpu 分配资源执行的顺序

 

 

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值