多线程

一、实现Runnable与继承Thread相比有如下优势

        1.通过创建任务对象,然后给线程分配的方式实现的多线程,更适合多个线程同时执行相同任务的情况;

        2.可以避免单继承所带来的局限性;

        3.任务与线程本身是分离的,提高了程序的健壮性;

二、线程与进程的区别

        进程:是指一个内存中运行的应用程序,每个进程都有一个独立的内存空间

        线程

                ①是进程中的一个执行路径,共享一个内存空间,线程之间可以自由切换,并发执行。一个进程最少有一个线程

                ②线程实际上是进程基础上的为进一步划分,一个进程启动后,里面的若干执行路径又可以划分为若干个线程

三、线程调度

    ①分时调度:所有线程轮流使用CPU的使用权,平均分配每个线程占用CPU的时间

    ②抢占式调度:优先让优先级高的线程使用CPU,如果线程的优先级相同,那么会随机选择一个(线程随机性),java使用的为抢占式调度。

    CPU使用抢占式调度模式在多个线程间进行着高速的切换,对于CPU的一个核心而言,某个时间只能执行一个线程,而CPU在多个线程间切换速度相对我们感觉要快,看上去就是在同一时刻运行。其实,多线程程序并不能提高程序的运行速度,但能够提高程序运行效率,让CPU的使用率更高。

四、同步与异步

        同步:排队执行,效率低但是安全

        异步:同时执行,效率高但是数据不安全

五、并发与并行

        并发:指两个或多个事件在同一个时间段内发生

        并行:指两个或多个事件在同一时刻发生(同时发生)

六、继承Thread

        重写run方法;创建对象;运行start()方法

         public void run() {}

          MyThread m = new MyThread();

           m.start();

七、实现Runnable接口

            重写run() 方法,创建任务对象;新建一个线程,并为其分配一个任务;执行这个线程

            public void run() {}

            MyRunnable r = new MyRunnable();

            Thread t = new Thread(r);

             t.start();

        ②可使用匿名内部类实现Runnable接口并重写run()方法

八、设置和获取线程名称

        Thread.currentThread().getName()

九、线程休眠sleep

        Thread.sleep()

十、java中的同步代码块、同步方法、同步锁

            1、多线程容易出现问题的原因:

                当多条语句在操作同一个线程共享数据时,一个线程对多条语句只执行了一部分,还没执行完,另一个线程参与进来执行。导致共享数据的错误。即多个线程执行的不确定性引起执行结果的不稳定。

        例如:多个线程对账本的共享,会照成操作的不完整性,会破坏数据

                    火车站售票,多个窗口同时售票。

            2、解决方法

                ①同步代码块

                    synchronized(obj)

                    {

                            //需要被同步的的代码块

                    }

                其中,obj称为同步监视器,也就是锁,原理:当线程开始执行同步代码块前,必须先获得对同步代码块的锁定。并且任何时刻只能有一个线程可以获得对同步监视器的锁定,当同步代码块执行后,该线程会释放对该同步监视器的锁定。

                ②同步方法

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容