好久没有更博客了,最近一直在忙工作的事情。现在终于空下来了,这2天会抓紧时间整理多线程和socket,把JavaSE结束掉。



关于多线程,首先会涉及到哪些东西呢?首先要了解线程,为什么要使用线程,线程有什么优势,线程和进程有什么区别呢?了解过大致的线程内容后,就应该编码来实现Java的多线程了。首先2种方式来创建线程类,然后调用对应的API来控制线程。然后还剩下一个最大的也是最重要的一块知识,就是线程同步。前面那些了解线程的生命周期就可以,实际编码中并不会多次写到那些编码,但是线程的同步经常要用到。同步代码块,同步方法,同步锁等等还是很重要的。最后就是一个线程池的问题了,这个了解下就好,在后面框架中有好多缓存技术使用了池技术的,我们也不需要编码了。





  • 线程和进程

实际开发中,特别是j2ee中,基本没有一个项目说是单线程的,都是多线程的。比如服务器处理多个请求。

  • 什么是进程?

几乎所有的操作系统都支持同时运行多个任务,一个任务通常就是一个程序,那么运行的这个程序就叫一个进程。进程的调度由OS负责(有的系统为独占式(Windows),有的系统为共享式(Unix),根据重要性,进程有优先级)。由OS 将时间分为若干个时间片。JAVA 在语言级支持多线程。分配时间的仍然是OS。

  • 什么是线程?

当一个程序运行时,内部可能包含了多个顺序执行流,那么这每一个顺序执行流就叫一个线程。

  • 关于他们2个之间的关系:

一个程序运行后至少有一个进程,一个进程里可以包含多个线程,但至少要包含一个线程。

线程是一个操作系统创建并维护的一个资源,对操作系统来说JVM就是一个进程。

对于单个CPU系统来说,某一个时刻只可能由一个线程在运行。一个Thread对象就表示一个线程。

进程是独立的数据空间,线程是共享的数据空间。线程对象存在于虚拟机进程空间的一块连续的地址空间(静态的)。

  • 关于线程注意:

1.线程是动态的,与线程对象是两回事.

   2.线程对象与其他对象不同的是线程对象能够到底层去申请管理一个线程资源。

   3.只有对线程对象调用start()方法才是到底层去申请管理一个线程资源。

   4.任务并发执行是一个宏观概念,微观上是串行的。

   5.只有等到所有的线程全部结束之后,进程才退出。进行多线程编程时不要忘记了Java程序运行时默认的主线程,main方法的方法体就是主线程的线程执行体。

  • 在这里要注意2个概念上的区别:并行和并发。

并行指的是在同一时刻,有多条指令在多个处理器上同时执行。

并发指的是在同一时刻,只能有一条指令执行。但是多个指令被快速轮换执行,使得在宏观上有多个进程同时执行。也就是说只是看起来是同时执行的,其实具体实际执行的还是一条而已。

  • 多线程的优势:

1,进程间不能共享内存,但是线程之间共享内存非常容易。

2,系统创建进程需要为进程重新分配系统资源,但创建线程则代价小得多,使用多线程实现多任务并发比多进程的效率高。

3,Java语言内置多线程功能支持,而不是单纯的作为底层操作系统的调度方式,从而简化了Java的多线程编程

  • 线程的创建和启动

一共有2种方式:1,继承Thread类  2,实现Runnable接口。代码如下:

  1. /**
  2. *
  3. * @version 1L
  4. * @author LinkinPark
  5. * @since 2015-2-3
  6. * @motto 梦似烟花心似水,同学少年不言情
  7. * @desc ^ 继承Thread,重写run方法。
  8. */
  9. public class MyThread extends Thread
  10. {
  11. private int i = 0;
  12.  
  13. public void run()
  14. {
  15. for (; i < 10; i++)
  16. {
  17. //输出中i不连续,说明这种方式不能共享一份系统资源
  18. System.out.println(this.getName() + " " + i);
  19. }
  20. }
  21.  
  22. public static void main(String[] args)
  23. {
  24. for (int i = 0; i < 100; i++)
  25. {
  26. //输出了主线程
  27. System.out.println(Thread.currentThread().getName() + " " + i);
  28. if (i == 20)
  29. {
  30. //这里开始抢占输出,注意的是i不连续
  31. new MyThread().start();
  32. new MyThread().start();
  33. }
  34. }
  35. }
  36. }
  1. public class MyThread1 implements Runnable
  2. {
  3. private int i = 0;
  4.  
  5. @Override
  6. public void run()
  7. {
  8. for (; i < 100; i++)
  9. {
  10. //输出中i连续,表明这种方式会共享同一份系统资源
  11. //这里没有Thread,所以只能通过这种方式:先返回当前正在执行的线程对象,然后在获得名字
  12. System.out.println(Thread.currentThread().getName() + " " + i);
  13. }
  14. }
  15.  
  16. public static void main(String[] args)
  17. {
  18. for (int i = 0; i < 100; i++)
  19. {
  20. //输出主线程
  21. System.out.println(Thread.currentThread().getName() + " " + i);
  22. if (i == 20)
  23. {
  24. MyThread1 myThread1 = new MyThread1();
  25. //这里开始抢占输出,注意的是i连续
  26. new Thread(myThread1, "林肯的第一个线程").start();
  27. new Thread(myThread1, "林肯的第二个线程").start();
  28. }
  29. }
  30. }
  31.  
  32. }
  • 关于这2种方式创建线程的对比:

首先有必要看一下Thread类的run方法的源码。代码如下:

  1. public void run() {
  2. if (target != null) {
  3. target.run();
  4. }
  5. }

这里有一个target,如何理解这个target呢?run方法又叫线程执行体,我们可以这样子来理解,线程呢就是一段程序流,这段程序流要操作一个对象,那么操作的这个对象就是这个target,值得注意的一点是Java语言的Thread必须使用Runnable对象里面的run方法。





言归正传,这2种实现方式的区别如下:

1,实现Runnable接口,还可以继承其他的类。Java是单继承呀,要是直接去继承Thread类的话就不能再继承别的类了

2,实现Runnable接口,多个线程可以共享同一个target对象,所以非常适合多个相同的线程来处理同一份资源

3,实现Runnable接口,编码稍微有点多。访问当前线程只能使用Thread.currentThread(),要是继承Thread类的话直接使用this就可以获得当前的线程。

Java多线程之线程的创建的更多相关文章

  1. Java多线程之线程其他类

    Java多线程之线程其他类 实际编码中除了前面讲到的常用的类之外,还有几个其他类也有可能用得到,这里来统一整理一下: 1,Callable接口和Future接口 JDK1.5以后提供了上面这2个接口, ...

  2. Java多线程之线程的通信

    Java多线程之线程的通信 在总结多线程通信前先介绍一个概念:锁池.线程因为未拿到锁标记而发生的阻塞不同于前面五个基本状态中的阻塞,称为锁池.每个对象都有自己的锁池的空间,用于放置等待运行的线程.这些 ...

  3. Java多线程之线程的同步

    Java多线程之线程的同步 实际开发中我们也经常提到说线程安全问题,那么什么是线程安全问题呢? 线程不安全就是说在多线程编程中出现了错误情况,由于系统的线程调度具有一定的随机性,当使用多个线程来访问同 ...

  4. Java多线程之线程的控制

    Java多线程之线程的控制 线程中的7 种非常重要的状态:  初始New.可运行Runnable.运行Running.阻塞Blocked.锁池lock_pool.等待队列wait_pool.结束Dea ...

  5. Java多线程父子线程关系 多线程中篇(六)

    有的时候对于Java多线程,我们会听到“父线程.子线程”的概念. 严格的说,Java中不存在实质上的父子关系 没有方法可以获取一个线程的父线程,也没有方法可以获取一个线程所有的子线程 子线程的消亡与父 ...

  6. Java多线程02(线程安全、线程同步、等待唤醒机制)

    Java多线程2(线程安全.线程同步.等待唤醒机制.单例设计模式) 1.线程安全 如果有多个线程在同时运行,而这些线程可能会同时运行这段代码.程序每次运行结果和单线程运行的结果是一样的,而且其他的变量 ...

  7. java多线程与线程间通信

    转自(http://blog.csdn.net/jerrying0203/article/details/45563947) 本文学习并总结java多线程与线程间通信的原理和方法,内容涉及java线程 ...

  8. Java多线程之线程的生命周期

    Java多线程之线程的生命周期 一.前言 当线程被创建并启动以后,它既不是一启动就进入了执行状态,也不是一直处于执行状态.在线程的生命周期中,它要经过新建(New).就绪(Runnable).运行(R ...

  9. Java多线程之线程的启动

    Java多线程之线程的启动 一.前言 启动线程的方法有如下两种. 利用Thread 类的子类的实例启动线程 利用Runnable 接口的实现类的实例启动线程 最后再介绍下java.util.concu ...

随机推荐

  1. Java学习笔记7(简易的超市库存管理系统示例)

    用以前学过的知识,可以简单地做一个超市库存管理系统: 定义一个商品类: public class FruitItem { int ID; String name; double price; int ...

  2. myeclipse 扩展内存大小

    工具中修改设置Default VM ArgumentsWindows-> Preferences->Java->Installed JREs,点击右侧的jdk,然后点击"E ...

  3. 软件安装之-------VM虚拟机安装windows系统

    一 准备工作 1 电脑已经安装上VMware Workstation 2 一个Windows系统,下载纯净版系统可到(www.itellyou.cn下载) 3  软碟通 下载可到(http://dow ...

  4. Oracle 11.2.0.1的又一个隐藏在ORA-03113后的bug: 通信通道的文件结尾

    近期又一个项目反馈ORA-03113错误: 通信通道的文件结尾.(jdbc程序报出的错误是:无法从套接字读取更多的数据) 发送之前处理过类似问题的解决方法(http://www.cnblogs.com ...

  5. hackerrank Ticket

    传送门 题意:n个人排队买票,要把他们拆成k条队到k个窗口买,可以有队伍为空,每条队的顺序保持拆之前的顺序.如果某人和他前一个人买的票相同,就可以打八折,求最小花费. 题解:拆成k条队意味着只有[n- ...

  6. 来说说datatype

    今天敲代码一直卡在一个问题上面好久那就是--datatype的未定义,起初不晓得datatype的含义,遇到这种情况首先想到的就是自己又忘记加上面头文件了.随即写了个stdlib.h上去.可是问题并没 ...

  7. Kafka监控安装

    p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...

  8. 调用webService的几种方式

    转自:http://blog.csdn.net/u011165335/article/details/51345224 一.概览 方式1: HttpClient:可以用来调用webservie服务,也 ...

  9. [国嵌攻略][164][USB驱动程序设计]

    USB驱动模型 1.USB host controller driver(主控器驱动):为USB主控制器提供驱动程序 2.USB core(USB核心):连接USB主控制器驱动和USB设备驱动 3.U ...

  10. PHPMailer发送邮件失败:SMTP connect failed

    标签: PHPMailersmtp邮件服务器邮件发送失败 2015-05-22 19:29 1755人阅读 评论(0) 收藏 举报 分类: Apache php+mysql(2) 版权声明:本文为博主 ...