java 线程和进程

 

 


 

 

一个进程中肯定,至少有一个线程。

多线程可以并发运行。一个病人和多个医生操作。

线程之间的切换远远高于进程之间的切换效率。所以用多线程替代多进程。

 

 


 

java.lang.Thread
一个Thread对象代表一个线程的对象



public class MyThread extends Thread{
    public void run()
    {
        System.out.println(getName());
    }
}
public class TestThread {
    public static void main(String[] args)
    {
        MyThread mt = new MyThread();
        mt.start();
        System.out.println("main:"+Thread.currentThread().getName());
    }
}


/*
结果是:
main:main//先打印main方法,因为多进程有时间片的切换。
Thread-0
*/


public class MyThread extends Thread{
    public void run()
    {
        while(true) //死循环
        System.out.println(getName());
    }
}
public class TestThread {
    public static void main(String[] args)
    {
        MyThread mt = new MyThread();
        mt.start();
while(true)//死循环
        System.out.println("main:"+Thread.currentThread().getName());
    }
}

//增加死循环就可以看到多进程的时间片切换




public class TestThread {
    public static void main(String[] args)
    {
        MyThread mt = new MyThread();
        mt.setDaemon(true);//在start之前使用,将该线程标记为守护线程或用户线程。
        mt.start();
        while(true)
        {
            System.out.println("main:"+Thread.currentThread().getName());
           
        }
    }
}

public class MyThread extends Thread{
    public void run()
    {
        while(true)
        {
            System.out.println(getName());
            yield();//暂停当前正在执行的线程对象,并执行其他线程。
        }
    }
}


mt.setPriority(Thread. MAX_PRIORITY _);//修改为最高的优先级

 

 


 

 

 

 

 

 

 

java.lang.Runnable 对于一个类来说,如果它的实例想要被一个线程去执行,那么就应该实现Runnable接口,那么这个类必须实现一个不带参数的run方法


class MyThread implements Runnable{
    public void run()
    {
        while(true)
        {
            System.out.println(Thread.currentThread().getName());
        }
    }
}
class TestThread {
    public static void main(String[] args)
    {
        MyThread mt = new MyThread();
        new Thread(mt).start();
        int index=0;
        while(true)
        {
            System.out.println("main:"+Thread.currentThread().getName());
           
        }
    }
}



两者的优缺:
如果并不需要修改线程中除了run方法之外的其它方法行为以外,我们最好都是去实现Runnabel接口;java不允许多继承,可以用实现接口来实现多线程;如果要达到共享同一个变量,继承类的实例就不行,最好是实现接口来共享一个成员变量



利用内部类:
class MyThread {
    int index=0;
    private class InnerThread extends Thread
    {
        public void run()
        {
            while(true)
            {
                System.out.println(Thread.currentThread().getName());
            }
        }
    }
    Thread getThread()
    {
        return new InnerThread();
    }
}
class TestThread {
    public static void main(String[] args)
    {
        MyThread mt = new MyThread();
        mt.getThread().start();
        mt.getThread().start();
        mt.getThread().start();
        mt.getThread().start();
        while(true)
        {
            System.out.println("main:"+Thread.currentThread().getName());
           
        }
    }
}


火车票售票系统:多线程来实现
class MyThread implements Runnable{
    int tickets=100;
    public void run()
    {
        while(true)
        {
            if(tickets>0)
            {
                System.out.println(Thread.currentThread().getName()+"sell tickets:"+tickets);
                tickets--;
            }
        }
    }
}

class TestThread {
    public static void main(String[] args)
    {
        MyThread mt = new MyThread();
        new Thread(mt).start();
        new Thread(mt).start();
        new Thread(mt).start();
        new Thread(mt).start();
    }
}



问题是没有锁关键步骤,应该加上同步块
class MyThread implements Runnable{
    int tickets=100;
    Object obj = new Object();
    public void run()
    {
        while(true)
        {
            synchronized(obj)//同步块,需要一个对象,来加锁
            {
                if(tickets>0)
                {
                    try
                    {
                        Thread.sleep(10);
                    }
                    catch(Exception e)
                    {
                        e.printStackTrace();
                    }
                    System.out.println(Thread.currentThread().getName()+"sell tickets:"+tickets);
                    tickets--;
                }
            }
        }
    }
}


class TestThread {
    public static void main(String[] args)
    {
        MyThread mt = new MyThread();
        new Thread(mt).start();
        new Thread(mt).start();
        new Thread(mt).start();
        new Thread(mt).start();
    }
}
同步方法

class MyThread implements Runnable{
    int tickets=100;
    Object obj = new Object();
    public void run()
    {
        while(true)
        {
            sell();
        }
    }
    public synchronized void sell()
    {
        if(tickets>0)
        {
            try
            {
                Thread.sleep(10);
            }
            catch(Exception e)
            {
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName()+"sell tickets:"+tickets);
            tickets--;
        }
    }
}



class TestThread {
    public static void main(String[] args)
    {
        MyThread mt = new MyThread();
        new Thread(mt).start();
        new Thread(mt).start();
        new Thread(mt).start();
        new Thread(mt).start();
    }
}

 

 

 


 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用中提到,多进程程序比多线程更加健壮,因为一个线程死掉不会导致整个进程崩溃,而一个进程崩溃不会对其他进程产生影响,因为进程有自己的独立的地址空间。引用中指出,线程是程序执行的最小单位,也被称为轻量级进程,是CPU调度和分派的基本单位。而引用中说明了进程线程的执行过程,进程相当于一个应用程序执行的实例,有自己的入口、顺序执行序列和出口,而线程不能独立执行,必须依赖于应用程序(进程)。 综上所述,Java线程进程的区别在于: 1. 进程是一个独立的执行实例,拥有独立的地址空间,一个进程的崩溃不会影响其他进程;而线程是一个程序执行的最小单位,不能独立执行,需要依赖于进程。 2. 多线程程序中,一个线程的死掉不会导致整个进程崩溃;而一个进程的崩溃也不会对其他进程产生影响。 3. 进程有自己的入口、顺序执行序列和出口;而线程依赖于应用程序(进程)提供的多个线程执行控制。 因此,Java线程进程之间的区别在于其执行实例的独立性和依赖关系。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [java基础:进程线程的区别](https://blog.csdn.net/weixin_41550144/article/details/87777739)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值