java多线程

一.1.一个程序运行后至少有一个进程,一个进程中可以包含多个线程,但至少有一个线程。
2.多线程运行原理:在某一时刻,只会运行一个进程。由于CPU(中央处理器)在做着高速的切换而导致的。对于CPU(中央处理器)而言,它在某个时间点上,只能执行一个程序,CPU(中央处理器)不断地在这些进程之间切换。
同步锁:当任何线程进入锁标识的这段代码时,首先都会先判断目前有没有线程正在使用锁标记对象,若有线程正在使用这个标记对象, 那么当前这个线程就在锁标识的外面等待,直到前一个执行完这个标记对象后,这个线程才能执行同步代码块。
3必然有一个执行路径(线程)从main()方法开始的。一直执行到main()方法结束。这个线程在java中称之为主线程.多线程可以解决一个主线程负责执行其中一个循环,由另一个线程负责其他代码的执行。
4.线程对象调用 ==run()方法==和调用==start()==方法区别:
线程对象调用run方法不开启线程。仅是对象调用方法。线程对象调用start开启线程,并让jvm调用run方法在开启的线程中执行。
5.实现Runnable的好处
第二种方式实现==Runnable==接口避免了单继承的局限性,所以较为常用。实现==Runnable==接口的方式,更加的符合面向对象,线程分为两部分,一部分线程对象,一部分线程任务。
6.线程的五大状态分别为:
(1)新建状态:即单纯地创建一个线程,创建线程有三种方式。
(2)就绪状态:在创建了线程之后,调用==Thread类==的==start()==方法来启动一个线程,即表示线程进入就绪状态!

(3)运行状态:当线程获得CPU时间,线程才从就绪状态进入到运行状态!

(4)阻塞状态:线程进入运行状态后,可能由于多种原因让线程进入阻塞状态,如:调用==sleep()==方法让线程睡眠,调用==wait()==方法让线程等待,调用==join()==方法、==suspend()==方法(它现已被弃用!)以及阻塞式IO方法。

(5)死亡状态:==run()==方法的正常退出就让线程进入到死亡状态,还有当一个异常未被捕获而终止了==run()==方法的执行也将进入到死亡状态!
其实是六个状态: NEW: 创建一个线程,尚未启动的线程 。RUNNABLED: 就绪状态,等待来自操作系统的分配资源 。BLOCKED: 阻塞,尝试获取Synchronized锁失败或者被唤醒以后还没获取锁的时候。 WAITING: 等待,调用了wait、sleep、join、park方法的时候,并且没超时。 TIMED_WAITING: 超时等待。 TERMINATED: 终止,线程已经完成执行。

5.3、线程方法

二.创建线程方式一:继承Thread类
创建线程的步骤:
1. 定义一个类继承Thread。
2.重写==run()方法==。
3. 创建子类对象,就是创建线程对象。
4. 调用==start()方法==,开启线程并让线程执行,同时还会告诉jvm去调用==run()方法==。
class Demo extends Thread  //继承Thread
{
    String name;
    Demo(String name)
    {
        this.name = name;
    }
    //复写其中的run方法
    public void run()
    {
        for (int i=1;i<=20 ;i++ )
        {
            System.out.println("name="+name+",i="+i);
        }
    }
}
class ThreadDemo 
{
    public static void main(String[] args) 
    {
        //创建两个线程任务
        Demo d = new Demo("小强");
        Demo d2 = new Demo("旺财");
        //d.run(); 这里仍然是主线程在调用run方法,并没有开启两个线程
        //d2.run();
        d2.start();//开启一个线程
        d.start();//主线程在调用run方法
    }
}
创建线程方式二:实现Runnable接口
1. 定义类实现==Runnable接口==。
2. 覆盖接口中的==run()方法==。
3. 创建==Thread类==的对象。
4. 将==Runnable接口==的子类对象作为参数传递给==Thread类==的构造函数。
5. 调用==Thread类==的==start()方法==开启线程。
class Demo implements Runnable
{
    private String name;
    Demo(String name)
    {
        this.name = name;
    }
    //覆盖了接口Runnable中的run方法。
    public void run()
    {
        for(int i=1; i<=20; i++)
        {            System.out.println("name="+name+"..."+Thread.currentThread().getName()+"..."+i);
        }
    }
}
class ThreadDemo2 
{
    public static void main(String[] args) 
    {
        //创建Runnable子类的对象。注意它并不是线程对象。
        Demo d = new Demo("Demo");
        //创建Thread类的对象,将Runnable接口的子类对象作为参数传递给Thread类的构造函数。
        Thread t1 = new Thread(d);
        Thread t2 = new Thread(d);
        //将线程启动。
        t1.start();
        t2.start();
        System.out.println(Thread.currentThread().getName()+"----->");
        System.out.println("Hello World!");
    }
}
创建线程方式二:实现Callable接口创建线程
(1)自定义一个类==MyThread==,实现Callable接口并覆写==Callable接口==的==call()==方法。

(2)利用MyThread类实例化Callable接口的对象。

(3)利用FutureTask类的构造方法public FutureTask(Claaable<V> callable),将Callable接口的对象传给FutureTask类

(4)将FutureTask类的对象隐式地向上转型,从而作为Thread类的public Thread(Runnable runnable)构造方法的参数

(5)这样就建立了Callable接口与Thread类之间的关系,再调用Thread类的start()方法。有返回值


同步锁加到run()中:
//接口Runnable
class suo implements Runnable{
static  int s=300;//总钱数s
//设置锁为lock
static Object lock=new Object();
//重写run方法
    @Override
    public void run() {
    while (true) {
//synchronized设置锁
        synchronized (lock) {
            if (s>0){
                s--;
            System.out.println(Thread.currentThread().getName() + "..." + s);
        }
        }
    }
    }
    public static void main(String[] args) {
//创建class的对象。class 对象名=new class();
suo q=new suo();
//设置线程1     Thread 线程名=new Thread(对象名);
        Thread a=new Thread(q);
//设置线程2
        Thread b=new Thread(q);
//启动线程  线程名.start();
a.start();
b.start();
    }
}


同步锁加到方法:
class bank2 implements Runnable{
private int money;
private Object lock=new Object();
public synchronized void add(int num){
    synchronized (lock){ money+=num;System.out.println(Thread.currentThread().getName()+"..."+money); } }
    @Override
    public void run() 
{ while (true){ if(money<1000){ add(100); } } }
        public static void main(String[] args) {
        bank2 bank=new bank2();
        Thread s1=new Thread(bank,"窗口1");
        Thread s2=new Thread(bank,"窗口2");
        s1.start();s2.start();
    }
}

线程休眠:指的是让线程暂缓执行,等到预计时间之后再恢复执行。

将线程暂时转为阻塞状态,执行其他线程,sleep(有时间)结束时才能转为就绪状态,期间循环时CPU不可能执行这个线程

线程让步:调用==yield()==方法让当前线程交出CPU权限,让CPU去执行其他线程 

将线程转为就绪状态 ,cpu执行其他线程,再次循环时有可能再次执行

等待线程终止:指的是如果在主线程中调用该方法时就会让主线程休眠,让调用==join()==方法的线程先执行完毕后再开始执行主线程。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于计算机专业的学生而言,参加各类比赛能够带来多方面的益处,具体包括但不限于以下几点: 技能提升: 参与比赛促使学生深入学习和掌握计算机领域的专业知识与技能,如编程语言、算法设计、软件工程、网络安全等。 比赛通常涉及实际问题的解决,有助于将理论知识应用于实践中,增强问题解决能力。 实践经验: 大多数比赛都要求参赛者设计并实现解决方案,这提供了宝贵的动手操作机会,有助于积累项目经验。 实践经验对于计算机专业的学生尤为重要,因为雇主往往更青睐有实际项目背景的候选人。 团队合作: 许多比赛鼓励团队协作,这有助于培养学生的团队精神、沟通技巧和领导能力。 团队合作还能促进学生之间的知识共享和思维碰撞,有助于形成更全面的解决方案。 职业发展: 获奖经历可以显著增强简历的吸引力,为求职或继续深造提供有力支持。 某些比赛可能直接与企业合作,提供实习、工作机会或奖学金,为学生的职业生涯打开更多门路。 网络拓展: 比赛是结识同行业人才的好机会,可以帮助学生建立行业联系,这对于未来的职业发展非常重要。 奖金与荣誉: 许多比赛提供奖金或奖品,这不仅能给予学生经济上的奖励,还能增强其成就感和自信心。 荣誉证书或奖状可以证明学生的成就,对个人品牌建设有积极作用。 创新与研究: 参加比赛可以激发学生的创新思维,推动科研项目的开展,有时甚至能促成学术论文的发表。 个人成长: 在准备和参加比赛的过程中,学生将面临压力与挑战,这有助于培养良好的心理素质和抗压能力。 自我挑战和克服困难的经历对个人成长有着深远的影响。 综上所述,参加计算机领域的比赛对于学生来说是一个全面发展的平台,不仅可以提升专业技能,还能增强团队协作、沟通、解决问题的能力,并为未来的职业生涯奠定坚实的基础。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值