什么是Java多线程编程?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了什么是Java多线程编程?相关的知识,希望对你有一定的参考价值。

一、 什么是多线程:

我们现在所使用操作系统都是多任务操作系统(早期使用的DOS操作系统为单任务操作系统),多任务操作指在同一时刻可以同时做多件事(可以同时执行多个程序)。

    多进程:每个程序都是一个进程,在操作系统中可以同时执行多个程序,多进程的目的是为了有效的使用CPU资源,每开一个进程系统要为该进程分配相关的系统资源(内存资源)

    多线程:线程是进程内部比进程更小的执行单元(执行流|程序片段),每个线程完成一个任务,每个进程内部包含了多个线程每个线程做自己的事情,在进程中的所有线程共享该进程的资源;

    主线程:在进程中至少存在一个主线程,其他子线程都由主线程开启,主线程不一定在其他线程结束后结束,有可能在其他线程结束前结束。Java中的主线程是main线程,是Java的main函数;

    二、 Java中实现多线程的方式:

    继承Thread类来实现多线程:

    当我们自定义的类继承Thread类后,该类就为一个线程类,该类为一个独立的执行单元,线程代码必须编写在run()方法中,run方法是由Thread类定义,我们自己写的线程类必须重写run方法。

    run方法中定义的代码为线程代码,但run方法不能直接调用,如果直接调用并没有开启新的线程而是将run方法交给调用的线程执行

    要开启新的线程需要调用Thread类的start()方法,该方法自动开启一个新的线程并自动执行run方法中的内容

    请点击输入图片描述

    结果:

    请点击输入图片描述

    java多线程的启动顺序不一定是线程执行的顺序,各个线程之间是抢占CPU资源执行的,所有有可能出现与启动顺序不一致的情况。

    CPU的调用策略:

    如何使用CPU资源是由操作系统来决定的,但操作系统只能决定CPU的使用策略不能控制实际获得CPU执行权的程序。

    线程执行有两种方式:

    1.抢占式:

    目前PC机中使用最多的一种方式,线程抢占CPU的执行权,当一个线程抢到CPU的资源后并不是一直执行到此线程执行结束,而是执行一个时间片后让出CPU资源,此时同其他线程再次抢占CPU资源获得执行权。

    2.轮循式;

    每个线程执行固定的时间片后让出CPU资源,以此循环执行每个线程执行相同的时间片后让出CPU资源交给下一个线程执行。

    希望对您有所帮助!~

参考技术A Java语言本身就是多线程的,因此为我们开发者提供了语言级的多线程支持,这个要比C/C++中使用多线程方便的多,同时Java为我们提供了很多便利的条件,使得我们开发多线程应用方便了很多,但是这也是相对而言的,想要开发出一个真正意义上的多线程应用很难,因为有太多的问题需要考虑,看得见的和看不见的。所以我们必须从理论上打好基础,然后做大量的练习,真正的了解多线程的机制,不断实践,才能写出漂亮的并发应用来。
以上内容均来自黑马程序员社区,想了解更多Java基础的话,建议你也去社区看看。里面不仅很多文字的内容,还有配套的课程,并且有视频+源码;本回答被提问者采纳
参考技术B Java 多线程编程

Java 给多线程编程提供了内置的支持。 一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。

多线程是多任务的一种特别的形式,但多线程使用了更小的资源开销。

这里定义和线程相关的另一个术语 - 进程:一个进程包括由操作系统分配的内存空间,包含一个或多个线程。一个线程不能独立的存在,它必须是进程的一部分。一个进程一直运行,直到所有的非守护线程都结束运行后才能结束。

多线程能满足程序员编写高效率的程序来达到充分利用 CPU 的目的。
参考技术C 线程是操作系统能够进行运算调度的最小单位;它被包含在进程之中,是进程中的实际运作单位。
多线程,是指从软件或者硬件上实现多个线程并发执行的技术。 …
简单来说:线程是程序中一个单一的顺序控制流程;而多线程就是在单个程序中同时运行多个线程来完成不同的工作。
多线程是为了同步完成多项任务,不是为了提高运行效率,而是为了提高资源使用效率来提高系统的效率。

史上最全Java多线程面试题及答案

点击上方蓝色文字关注↑↑↑↑↑


多线程并发编程是Java编程中重要的一块内容,也是面试重点覆盖区域。所以,学好多线程并发编程对Java程序员来来说极其重要的。

下面小编整理了60道最常见的Java多线程面试题及答案,供你学习或者面试参考。

  1. 多线程有什么用?

  2. 线程和进程的区别是什么?

  3. Java实现线程有哪几种方式?

  4. 启动线程方法start()和run()有什么区别?

  5. 怎么终止一个线程?如何优雅地终止线程?

  6. 一个线程的生命周期有哪几种状态?它们之间如何流转的?

  7. 线程中的wait()和sleep()方法有什么区别?

  8. 多线程同步有哪几种方法?

  9. 什么是死锁?如何避免死锁?

  10. 多线程之间如何进行通信?

  11. 线程怎样拿到返回结果?

  12. violatile关键字的作用?

  13. 新建T1、T2、T3三个线程,如何保证它们按顺序执行?

  14. 怎么控制同一时间只有3个线程运行?

  15. 为什么要使用线程池?

  16. 常用的几种线程池并讲讲其中的工作原理。

  17. 线程池启动线程submit()和execute()方法有什么不同?

  18. CyclicBarrier和CountDownLatch的区别?

  19. 什么是活锁、饥饿、无锁、死锁?

  20. 什么是原子性、可见性、有序性?

  21. 什么是守护线程?有什么用?

  22. 怎么中断一个线程?如何保证中断业务不影响?

  23. 一个线程运行时发生异常会怎样?

  24. 什么是重入锁?

  25. Synchronized有哪几种用法?

  26. Fork/Join框架是干什么的?

  27. 线程数过多会造成什么异常?

  28. 说说线程安全的和不安全的集合。

  29. 什么是CAS算法?在多线程中有哪些应用。

  30. 怎么检测一个线程是否拥有锁?

  31. Jdk中排查多线程问题用什么命令?

  32. 线程同步需要注意什么?

  33. 线程wait()方法使用有什么前提?

  34. Fork/Join框架使用有哪些要注意的地方?

  35. 线程之间如何传递数据?

  36. 保证"可见性"有哪几种方式?

  37. 说几个常用的Lock接口实现锁。

  38. ThreadLocal是什么?有什么应用场景?

  39. ReadWriteLock有什么用?

  40. FutureTask是什么?

  41. 怎么唤醒一个阻塞的线程?

  42. 不可变对象对多线程有什么帮助?

  43. 多线程上下文切换是什么意思?

  44. Java中用到了什么线程调度算法?

  45. Thread.sleep(0)的作用是什么?

  46. Java内存模型是什么,哪些区域是线程共享的,哪些是不共享的

  47. 什么是乐观锁和悲观锁?

  48. Hashtable的size()方法为什么要做同步?

  49. 同步方法和同步块,哪种更好?

  50. 什么是自旋锁?

  51. Runnable和Thread用哪个好?

  52. Java中notify和notifyAll有什么区别?

  53. 为什么wait/notify/notifyAll这些方法不在thread类里面?

  54. 为什么wait和notify方法要在同步块中调用?

  55. 为什么你应该在循环中检查等待条件?

  56. Java中堆和栈有什么不同?

  57. 你如何在Java中获取线程堆栈?

  58. 如何创建线程安全的单例模式?

  59. 什么是阻塞式方法?

  60. 提交任务时线程池队列已满会时发会生什么?

近期精选




Java技术栈



架构|分布式|技术教程|面经



以上是关于什么是Java多线程编程?的主要内容,如果未能解决你的问题,请参考以下文章

Java多线程编程核心——Java多线程技能

Java多线程编程

Java 多线程编程

并发编程:线程与多线程必知必会

Java EE-多线程编程 认识线程

Java多线程编程