Java是最早开始有并发的语言之一,再过去传统多任务的模式下,人们发现很难解决一些更为复杂的问题,这个时候我们就有了并发.

引用

       多线程比多任务更加有挑战。多线程是在同一个程序内部并行执行,因此会对相同的内存空间进行并发读写操作。这可能是在单线程程序中从来不会遇到的问题。其中的一些错误也未必会在单CPU机器上出现,因为两个线程从来不会得到真正的并行执行。然而,更现代的计算机伴随着多核CPU的出现,也就意味着不同的线程能被不同的CPU核得到真正意义的并行执行。


       那么,要开始Java并发之路,就要开始从java线程开始说起.

       本篇幅将是本系列博客的开山篇,也就是基础线程的复习.

线程简介

线程百科

  1. 线程,有时被称为轻量级进程(Lightweight ProcessLWP),是程序执行流的最小单元。一个标准的线程由线程ID,当前指令指针(PC),寄存器集合和堆栈组成。另外,线程是进程中的一个实体,是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,只拥有一点儿在运行中必不可少的资源,但它可与同属一个进程的其它线程共享进程所拥有的全部资源。

线程优点

资源利用率更好

程序设计在某些情况下更简单

程序响应更快

线程代价

设计更复杂

上下文切换的开销上升

增加资源消耗

线程的实现方式

       线程我们有不同的实现方式,生产环境中用到的也有所不同,那么,我们先来通过Demo看一下每种实现方式的区别.

通过Thread 实现的线程

  1. public class Demo1 {
  2. public static void main(String args[]) {
  3. Thread thread = Thread.currentThread();
  4. System.out.println("当前线程:" + thread);
  5. thread.setName("hyh thread");//修改线程名称
  6. System.out.println("修改名称之后:" + thread);
  7. try {
  8. for (int a = 5; a > 0; a--) {
  9. System.out.println(a);
  10. thread.sleep(1000);
  11. }
  12. } catch (Exception e) {
  13. System.out.println("出现异常");
  14. }
  15. }

通过集成Runnable接口实现

Demo2.class 清单:

  1. public class Demo2 implements Runnable {
  2. Thread t;
  3. //空构造函数
  4. Demo2() {
  5. t = new Thread(this, "测试线程");
  6. System.out.println("子线程" + t);
  7. t.start();
  8. }
  9. public void run() {
  10. try {
  11. for (int a = 5; a > 0; a--) {
  12. System.out.println("子线程" + a);
  13. Thread.sleep(1000);
  14. }
  15. } catch (InterruptedException e) {
  16. System.out.println("异常");
  17. }
  18. System.out.println("退出子线程");
  19. }
  20. }
  21. /**
  22. * 主类
  23. */
  24. class ThreadDemo {
  25. public static void main(String args[]) {
  26. new Demo2();//创建一个新线程
  27. try {
  28. for (int i = 5; i > 0; i--) {
  29. System.out.println("主线程:" + i);
  30. Thread.sleep(1000);
  31. }
  32. } catch (InterruptedException e) {
  33. System.out.println("主线程异常");
  34. }
  35. //主线程退出
  36. System.out.println("主线程退出");
  37. }
  38. }

通过集成 Thread 重写run方法实现

  1. public class Demo3 extends Thread {
  2. public Demo3() {
  3. //创建新线程
  4. super("线程Demo");
  5. System.out.println("子线程:" + this);
  6. start();
  7. }
  8. @Override
  9. public void run() {
  10. try {
  11. for (int a = 5; a > 0; a--) {
  12. System.out.println("子线程:" + a);
  13. Thread.sleep(500);
  14. }
  15. } catch (InterruptedException e) {
  16. System.out.println("子程序异常");
  17. }
  18. }
  19. }
  20. class MasterThread {
  21. public static void main(String args[]) {
  22. new Demo3();//创建新线程
  23. try {
  24. for (int i = 5; i > 0; i--) {
  25. System.out.println("主线程:" + i);
  26. Thread.sleep(1000);
  27. }
  28. } catch (InterruptedException e) {
  29. System.out.println("主程序异常");
  30. }
  31. System.out.println("主程序退出...");
  32. }
  33. }

三个线程的实现

在日常生产中,使用线程可以通过实现Runnable接口.下面我们通过该方法实现简单的三个线程Demo

结构: 创建一个Demo4类,另外一个主类MultThreadDemo.

清单:

  1. public class Demo4 implements Runnable {
  2. //全局变量
  3. String name;
  4. Thread thread;
  5. //构造器
  6. public Demo4(String th) {
  7. name = th;
  8. thread = new Thread(this, name);
  9. System.out.println("新线程" + thread);
  10. //开始线程
  11. thread.start();
  12. }
  13. //重写run方法
  14. public void run() {
  15. try {
  16. for (int a = 5; a > 0; a--) {
  17. System.out.println(name + ":" + a);
  18. Thread.sleep(1000);
  19. }
  20. } catch (InterruptedException e) {
  21. System.out.println("异常");
  22. }
  23. System.out.println(name + "线程结束");
  24. }
  25. }
  26. /**
  27. * 测试类
  28. *
  29. * @author hyh
  30. */
  31. class MultThreadDemo {
  32. public static void main(String[] args) {
  33. //创建三个线程
  34. Demo4 thread_1 = new Demo4("线程一");
  35. Demo4 thread_2 = new Demo4("线程二");
  36. Demo4 thread_3 = new Demo4("线程三");
  37. //查看状态
  38. System.out.println("线程一状态:" + thread_1.thread.isAlive());
  39. System.out.println("线程二状态:" + thread_2.thread.isAlive());
  40. System.out.println("线程三状态:" + thread_3.thread.isAlive());
  41. try {
  42. System.out.println("等待其他线程结束");
  43. //使用join确保主线程最后运行
  44. thread_1.thread.join();
  45. thread_2.thread.join();
  46. thread_3.thread.join();
  47. } catch (InterruptedException e) {
  48. System.out.println("线程异常");
  49. }
  50. //查看状态
  51. System.out.println("线程一:" + thread_1.thread.isAlive());
  52. System.out.println("线程二:" + thread_2.thread.isAlive());
  53. System.out.println("线程三:" + thread_3.thread.isAlive());
  54. }
  55. }

到此,开山Demo完成.

本文源码Github地址:

https://github.com/hanyahong/com-hanyahong-blog/tree/master/com-hanyahong-thread-1/src/main/java/com/hyh/thread

思考:进程与线程的比较

进程

资源分配的基本单位。

所有与该进程有关的资源,都被记录在进程控制块PCB中。

进程处理机的调度单位,拥有完整的虚拟地址空间。当进程发生调度时,不同的进程拥有不同的虚拟地址空间,而同一进程内的不同线程共享同一地址空间。

线程与资源分配无关,属于某一个进程,并与其他线程共享进程资源。

线程只由相关堆栈(系统栈或用户栈)寄存器和线程控制表TCB组成。寄存器可被用来存储线程内的局部变量,但不能存储其他线程的相关变量。

进程在多线程中,进程不是一个可执行的实体。

两者比较:

调度和切换:线程上下文切换比进程上下文切换要快得多。

通信:进程间通信IPC,线程间可以直接读写进程数据段(如全局变量)来进行通信——需要进程同步和互斥手段的辅助,以保证数据的一致性。

地址空间和其它资源(如打开文件):进程间相互独立,同一进程的各线程间共享。某进程内的线程在其它进程不可见。

(本篇完)

WeChat: wixf150

原创文章,转发请注明出处:http://www.cnblogs.com/hyhnet/p/6250264.html

访问独立站点,获得更好用户体验:http://www.hanyahong.com

[高并发]Java高并发编程系列开山篇--线程实现的更多相关文章

  1. [ 高并发]Java高并发编程系列第二篇--线程同步

    高并发,听起来高大上的一个词汇,在身处于互联网潮的社会大趋势下,高并发赋予了更多的传奇色彩.首先,我们可以看到很多招聘中,会提到有高并发项目者优先.高并发,意味着,你的前雇主,有很大的业务层面的需求, ...

  2. 原创】Java并发编程系列2:线程概念与基础操作

    [原创]Java并发编程系列2:线程概念与基础操作 伟大的理想只有经过忘我的斗争和牺牲才能胜利实现. 本篇为[Dali王的技术博客]Java并发编程系列第二篇,讲讲有关线程的那些事儿.主要内容是如下这 ...

  3. java并发编程系列原理篇--JDK中的通信工具类Semaphore

    前言 java多线程之间进行通信时,JDK主要提供了以下几种通信工具类.主要有Semaphore.CountDownLatch.CyclicBarrier.exchanger.Phaser这几个通讯类 ...

  4. 【DevOps】团队敏捷开发系列--开山篇

    随着软件发布迭代的频率越来越高,传统的「瀑布型」(开发-测试-发布)模式已经不能满足快速交付的需求.2009 年左右 DevOps 应运而生,开发运维一体化,通过自动化工具与流程让整个软件开发构建.测 ...

  5. 并发编程系列小结(线程安全,synchronized,脏读,线程间的通信wait/notify,线程的三种实现方式Demo,可替代wait/notify的方法)

    线程安全: 当多个线程访问某一个类(对象或方法)时,这个类始终都能表现出正确的行为,那么这个类(对象或方法就是线程安全的) synchronized: 可以在任意对象或方法上加锁,而加锁的这段代码称为 ...

  6. 【Java_多线程并发编程】基础篇—线程状态及实现多线程的两种方式

    1.Java多线程的概念 同一时间段内,位于同一处理器上多个已开启但未执行完毕的线程叫做多线程.他们通过轮寻获得CPU处理时间,从而在宏观上构成一种同时在执行的假象,实质上在任意时刻只有一个线程获得C ...

  7. Java Native Interface 编程系列一

    本文是<Java Native Interface Programmer's Guide and Specification>的读书笔记 Java Native Interface可以让编 ...

  8. 【Java_多线程并发编程】基础篇——线程状态扭转函数

    1. wait() sleep() yield() join()用法与区别 本文提到的当前线程是指:当前时刻,获得CPU资源正在执行的线程. 1.1 wait()方法 wait()方法定义在Objec ...

  9. 【微框架】之一:从零开始,轻松搞定SpringCloud微框架系列--开山篇(spring boot 小demo)

    Spring顶级框架有众多,那么接下的篇幅,我将重点讲解SpringCloud微框架的实现 Spring 顶级项目,包含众多,我们重点学习一下,SpringCloud项目以及SpringBoot项目 ...

随机推荐

  1. Sublime Text3配置在可交互环境下运行python快捷键

    安装插件 在Sublime Text3下面写代码感觉很不错,但是写Python的时候遇到了一些问题. 用Sublime Text3打开python文件,或者在Sublime Text3下写好pytho ...

  2. xamarin DependencyService源码阅读

    xamarin在面对PCL无法实现的各平台特有功能时使用了一种叫[DependencyService]的方式来实现.它使得xamarin能像原生平台一样做平台能做到的事情!主要分四个部分 接口:定义功 ...

  3. HTML5 语义元素(一)页面结构

    本篇主要介绍HTML5增加的语义元素中关于页面结构方面的,包含: <article>.<aside>.<figure>.<figcaption>.< ...

  4. 在ASP.NET Core应用中如何设置和获取与执行环境相关的信息?

    HostingEnvironment是承载应用当前执行环境的描述,它是对所有实现了IHostingEnvironment接口的所有类型以及对应对象的统称.如下面的代码片段所示,一个HostingEnv ...

  5. 将 instance 部署到 OVS Local Network - 每天5分钟玩转 OpenStack(130)

    上一节创建了 OVS 本地网络 first_local_net,今天我们会部署一个 instance 到该网络并分析网络结构.launch 一个 instance,选择 first_local_net ...

  6. C#中5步完成word文档打印的方法

    在日常工作中,我们可能常常需要打印各种文件资料,比如word文档.对于编程员,应用程序中文档的打印是一项非常重要的功能,也一直是一个非常复杂的工作.特别是提到Web打印,这的确会很棘手.一般如果要想选 ...

  7. .NET应用和AEAI CAS集成详解

    1 概述 数通畅联某综合SOA集成项目的统一身份认证工作,需要第三方系统配合进行单点登录的配置改造,在项目中有需要进行单点登录配置的.NET应用系统,本文专门记录.NET应用和AEAI CAS的集成过 ...

  8. bzoj1584--DP

    题目大意:有N头奶牛,每头那牛都有一个标号Pi,1 <= Pi <= M <= N <= 40000.现在Farmer John要把这些奶牛分成若干段,定义每段的不河蟹度为:若 ...

  9. BZOJ 3110: [Zjoi2013]K大数查询 [树套树]

    3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6050  Solved: 2007[Submit][Sta ...

  10. 归并排序的java实现

    归并排序的优点不说了. 做归并排序之前,我先试着将两个有序数组进行排序,合并成一个有序数组. 思路:定义好两个有序数组,理解的时候我先思考了数组只有一个数组的排序,然后是两个元素的数组的排序,思路就有 ...