`
avaj
  • 浏览: 236258 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

java多线程复习

阅读更多
一、进程与线程

每一个进程都独享一块内存空间。一个应用程序可以同时启动多个进程,比如IE浏览器,打开一个IE浏览器,就相当于开启了一个进程。

线程指进程中的一个执行流程,一个进程可以包含多个线程。

每个进程都需要操作系统为其分配独立的内存地址,而同一进程中的多个线程在同一块地址空间工作,他们共享一块内存和资源。

每次调用java.exe的时候操作系统都会启动一个java虚拟机进程,当启动java虚拟机进程的时候,java虚拟机都会创建一个主线程,改线程从 程序入口main方法开始执行,这个线程的名字就叫main( Thread.currentThread().getName())

java虚拟机每启动一个线程,就给他分配一块线程方法栈,用来存放相关信息(比如局部变量等),线程就在这个栈上运行。所以java中对象的局部变量是线程安全的,但是实力变量以及类变量由于不是保存在栈中,所以他们不是线程安全的。

二、线程的创建和启动

java中有两中方法创建一个多线程的类

1、继承java.lang.Thread类,覆盖Thread类的run()方法
2、实现Runnable接口,实现Runnable接口的run()方法。推荐使用第二种,因为第二种更加的灵活。

注意:每次程序运行的时候除了自定义的线程外还有一个main线程:
java 代码
  1. public class ThreadTest2 implements Runnable {

  2. /* (non-Javadoc)
  3. * @see java.lang.Runnable#run()
  4. */
  5. public void run() {
  6. for(int i=0;i<3;i++){
  7. System.out.println(Thread.currentThread().getName()+" "+i);
  8. }
  9. }

  10. /**
  11. * @param args
  12. */
  13. public static void main(String[] args) {
  14. Runnable r = new ThreadTest2();
  15. Thread t1 = new Thread(r,"t1");//创建线程t1
  16. Thread t2 = new Thread(r,"t2");//创建线程t2
  17. t1.start();//启动线程t1,这时候他处在Runnable状态,等待cpu
  18. t2.start();//启动线程t2,这时候他处在Runnable状态,等待cpu
  19. t1.run();//主线程main调,用对象t1的run()方法。
  20. }
  21. }

运行结果可能是:
main 0
main 1
main 2
t1 0
t1 1
t1 2
t2 0
t2 1
t2 2

三、线程的调度

线程调度的几个常用的方法,这几个方法都是Thread的静态方法:sleep();yield();join()

sleep(xxx),指当前运行的线程睡眠xxx秒,睡眠的时候当前线程会交出cpu,以便给其他线程运行的机会,但是不会交出对象的锁!

yield(),指当前运行的线程交出cpu,给其他线程运行的机会。yield()与sleep()的区别在于:yield()只给同等级别,或者比自 己级别还高的线程运行的机会,而sleep()是给所有线程运行的机会()。貌似yield()与操作系统关系很大。

join(),指将cpu交给调用join()方法的线程,直到他运行结束,在一定程度上可以实现synchronized类似的功能。

四、线程的各种状态

新建状态(new) //线程刚被创建出来
        Runnable r = new ThreadTest2();
        Thread t1 = new Thread(r,"t1");//创建线程t1 线程处在new状态

就绪状态(Runnable)
        t1.start();//启动线程t1,这时候他处在Runnable状态,等待cpu

运行状态(Running)
       如果处在Runnable状态的线程,被调度获得cpu,那么他就处在Running状态

阻塞状态(Blocked)
       如果Running中的线程调用sleep(),yield()等方法,他 就处在阻塞状态

死亡状态(Dead)
       线程执行完毕,就处于死亡状态。

五、线程同步

       线程同步使用synchronized关键字来惊进行。

       每一个对象都有一把锁,可以想象对象有一个等待池,一个对象锁池。
      
       因为每个对象都有一把锁,所以对同一个对象的不同方法使用synchronized,他们的锁只有一把,就是对象的本身。

       一个线程获得了对象的锁,其余的线程就得在对象锁池中等待当前线程释放对象的锁。

六、线程通讯:

       Object的两个方法;wait()和notify()实现线程之间的通讯。

       wait()使对象放弃cpu,释放对象的锁。jvm将该线程放到该对象的等待池中,等待其他线程将其唤醒
       notify()执行改方法的线程唤醒在对象的等待池中等待的一个线程,jvm从对象等待池中随机选择一个线程,把他转换到对象的锁池中
分享到:
评论
1 楼 xiaoyao3857 2011-09-08  
这个倒有些启发,不过博主如果能说明为什么上面的程序运行结果是那样的,就更好了

相关推荐

    实验八:Java多线程

    ### 实验八:Java多线程 #### 一、实验目的与知识点概述 在本实验中,我们将深入了解线程与进程的基本概念、它们之间的区别与联系,并掌握多线程技术在Java中的应用方法。具体包括以下几点: 1. **线程与进程的...

    java期末考试复习题库

    Java是一种广泛应用于软件开发的高级编程语言,它具有平台独立性、对象导向、分布式、多线程、动态链接、安全性等特点。Java语言的基本结构包括变量、数据类型、运算符、控制流语句、方法、数组、类、继承、接口、...

    43道Java多线程高频题整理(附答案背诵版).md

    这份《43道Java多线程高频题整理(附答案背诵版)》资源是一份专门针对Java多线程编程的高频考题集,旨在帮助Java开发者系统掌握多线程的核心概念和实际应用。此资源涵盖了面试和工作中常见的多线程问题,通过详细的...

    JAVA书本复习题答案整合

    6. **多线程**:Java提供了强大的多线程支持,复习题可能涉及线程的创建、同步机制(synchronized、wait()、notify()、join()等)、线程池的使用,以及死锁和活锁的问题。 7. **泛型**:泛型的引入提高了代码的类型...

    java_复习题库java_复习题库

    6. **多线程**:Java提供了内置的多线程支持,包括Thread类和Runnable接口。理解同步与互斥,熟悉synchronized关键字、wait()、notify()、notifyAll()方法以及并发工具类如Semaphore、CyclicBarrier。 7. **反射...

    Java多线程的互斥原理.pdf

    Java多线程的互斥原理.pdf 学习资料 复习资料 教学资源

    JAVA复习题库JAVA复习题库

    6. **多线程** - **线程的创建**:通过实现Runnable接口或继承Thread类创建线程。 - **同步机制**:synchronized关键字、wait()、notify()和notifyAll()的使用,以及死锁的概念。 - **线程池**:ExecutorService...

    Java SE 复习资料

    它提供了丰富的类库,包括集合框架、I/O流、多线程、网络编程、数据库连接等,是Java开发者必备的基础知识。 Java SE复习资料通常涵盖以下几个核心领域: 1. **基础语法**:这是学习Java的第一步,包括数据类型...

    JAVA课程总复习

    7. **多线程**:介绍线程的概念,创建线程的方式(继承Thread类和实现Runnable接口),线程同步和通信机制(如synchronized关键字、wait/notify、Semaphore等)。 8. **反射**:探讨如何在运行时动态获取类的信息并...

    Java基础考试复习资料

    10. **多线程**:Java支持多线程编程,理解Thread类、Runnable接口、同步机制(synchronized关键字、wait()、notify()、notifyAll())以及并发工具类如ExecutorService、Semaphore等。 11. **反射机制**:Java反射...

    计算机后端-Java-Java核心基础-第20章 多线程 02. 复习:IDEA使用与多线程基本概念.avi

    计算机后端-Java-Java核心基础-第20章 多线程 02. 复习:IDEA使用与多线程基本概念.avi

    Java期末复习题 Java 期末 复习题

    8. **线程同步**:Java提供了多种线程同步机制,如`synchronized`关键字、`wait()`, `notify()`, `notifyAll()`,以及`Lock`接口等,用于控制多线程对共享资源的访问,防止数据不一致。 9. **final关键字**:`final...

    java多线程应用实现方法

    这一篇文章主要关于java多线程,主要还是以例子来驱动的。因为讲解多线程的书籍和文章已经很多了,所以我也不好意思多说,呵呵、大家可以去参考一些那些书籍。我这个文章主要关于实际的一些问题。同时也算是我以后...

    Java期末复习||应用程序设计-多线程和泛型

    Java中的多线程和泛型是程序设计中的关键概念,它们极大地增强了代码的并发性和可复用性。在Java中,实现多线程有两种主要方式:一是通过继承`Thread`类,二是通过实现`Runnable`接口。通常推荐使用实现`Runnable`...

    Java期末复习资料_第1章_Java入门_.pdf

    4. 多线程:Java提供了内置的多线程支持,允许程序同时执行多个线程,进行多任务处理。 5. 动态性:Java支持动态加载类和运行时类型信息,可以在运行时发现和加载新的类库。 Java的开发步骤具体包括: 1. 编写...

    Java详细复习提纲

    - 多线程(Multithreading):Java支持并发编程,通过Thread类或Runnable接口创建线程。 四、Java标准库 Java标准库提供了大量的类和接口,涵盖了I/O、网络编程、集合框架、XML处理、日期时间、数据库连接等许多...

    java学习多线程处理

    Java学习中的多线程处理是程序设计中的重要概念,它涉及到进程、线程以及它们的交互。进程是应用程序的执行实例,具备动态性、并发性和独立性,这意味着它可以同时进行多个任务。线程则是在进程中执行的一个单元,是...

    java期末考试复习资料

    【Java期末考试复习知识点】 1. 计算与比较班级平均成绩和方差 ...在实际编程中,还需要学习更多高级主题,如面向对象编程、异常处理、集合框架、IO流、多线程等,这些都是Java开发者必备的知识。

    Java基础知识复习资料.rar

    - 多线程是让程序同时执行多个任务的能力,Java通过Thread类和Runnable接口实现。 - 同步机制(synchronized关键字、wait()、notify())防止多个线程对共享资源的竞态条件。 - 线程池(ExecutorService)用于高效...

    E05_多线程复习.pdf

    在计算机科学中,多线程是并发编程的重要概念,它允许多个任务在同一时间执行,提高了系统的效率和响应性。本文将深入探讨多线程的相关知识点。 1. **进程与线程** - **进程**:是操作系统分配资源的基本单位,每...

Global site tag (gtag.js) - Google Analytics