一、Java中实现多线程的两种方式
1) 继承Thread类
Thread类包括了包括和创建线程所需的一切东西。

Thread 最重要的方法是 run()。编写线程程序时须要覆盖 run() 方法,run() 方法是与别的线程并行运行的,故存在资源竞争和同步问题。

。Thread 还包括一个特殊的方法 start()。其作用是对线程进行特殊的初始化。然后调用run()。
调用start方法方可启动线程,而run方法仅仅是thread的一个普通方法调用。还是在主线程里运行。应该把须要并行处理的代码放在run()方法中,start()方法启动线程将自己主动调用 run()方法,这是由jvm的内存机制规定的。

而且run()方法必须是public訪问权限。返回值类型为void.。
2) 实现Runable接口
Runable接口仅仅有一个函数 run(),该函数必须由实现了该接口的类来实现。

使用 Runable 接口的时候不能直接创建所需类的对象并运行它,而必须从 Thread 类的一个实例内部运行。

二、线程状态
线程生命周期中共同拥有4中状态:新状态、可运行状态、死亡状态和堵塞状态。当中,
新状态:线程已创建。而start()还没有调用;
可运行状态:线程可以运行,等待CPU时间被分配给该线程后就可以;
死亡状态:run()返回后线程就会死亡。

或者调用stop()或者destroy()方法也会使得线程死亡。然而stop()会产生异常,destroy()则是强制终止从而没有释放锁;
堵塞状态:线程不会被分配CPU时间,无法运行。

堵塞状态情况比較复杂,线程进入堵塞状态的原因主要是:
1)调用sleep(ms),进入睡眠
2)调用suspend(),挂起线程。(调用resume()恢复运行)
3)调用wait(),暂停线程。(调用notify()或者notifyAll()恢复运行)
4)I/O 堵塞
5)调用还有一个处于锁定状态的对象的同步方法

三、对象的锁
Java中全部对象都具有隐式关联的监视程序,即“锁”。

程序不用去生成一个锁的对象,由于不论什么对象都具有了锁,通常在程序中都使用this对象。

与锁有关的方法有:
1)wait()
调用该方法的线程须要等待。直到得到该对象的锁,线程才干继续运行。
2)wait(long)和wait(long,int)
传递的參数指定了线程可以等到的最长时间。假设指定时间内没有得到锁,则会抛出异常interrupedException,程序处理完异常后继续运行。
3)notify()和notifyAll()
在锁对象上调用notify()或者notifyAll()方法就行释放对象上的锁。

当中,notify()仅仅能唤醒一个等待该锁的线程;而notifyAll()则会唤醒全部等待该锁的线程,然而被唤醒的线程中哪个会获得锁是由虚拟机来决定的。

四、线程的同步
synchronized 语句通过使用对象锁同步多个线程对某一特定代码段的訪问,在不论什么时候都仅仅能有一个线程来运行被保护的代码。

synchronized (taskQueue) {
newTask.setTaskId(++taskCounter);
newTask.setSubmitTime(new Date());
taskQueue.add(newTask);
/* 唤醒队列, 開始运行 */
taskQueue.notifyAll();
}

以上样例中,运行 synchronized (taskQueue) 。线程必须取得对象taskQueue的锁。假设线程没有获取到对象taskQueue的锁。线程就会停止在 synchronized 指令上。

直到线程离开 synchronized 指令保护的代码段,线程会将锁返回给对象taskQueue。

Java的线程机制的更多相关文章

  1. java中线程机制

    java中线程机制,一开始我们都用的单线程.现在接触到多线程了. 多线性首先要解决的问题是:创建线程,怎么创建线程的问题: 1.线程的创建: 四种常用的实现方法 1.继承Thread. Thread是 ...

  2. 一步一步掌握java的线程机制(二)----Thread的生命周期

    之前讲到Thread的创建,那是Thread生命周期的第一步,其后就是通过start()方法来启动Thread,它会执行一些内部的管理工作然后调用Thread的run()方法,此时该Thread就是a ...

  3. 一步一步掌握java的线程机制(一)----创建线程

    现在将1年前写的有关线程的文章再重新看了一遍,发现过去的自己还是照本宣科,毕竟是刚学java的人,就想将java的精髓之一---线程进制掌握到手,还是有点难度.等到自己已经是编程一年级生了,还是无法将 ...

  4. Java的多线程机制系列:(一)总述及基础概念

    前言 这一系列多线程的文章,一方面是个人对Java现有的多线程机制的学习和记录,另一方面是希望能给不熟悉Java多线程机制.或有一定基础但理解还不够深的读者一个比较全面的介绍,旨在使读者对Java的多 ...

  5. Java多线程与并发库高级应用-传统线程机制回顾

    1.传统线程机制的回顾 1.1创建线程的两种传统方式 在Thread子类覆盖的run方法中编写运行代码 // 1.使用子类,把代码放到子类的run()中运行 Thread thread = new T ...

  6. Java线程机制学习

    前面的文章中总结过Java中用来解决共享资源竞争导致线程不安全的几种常用方式: synchronized: ReentrantLock: ThreadLocal: 这些都是在简单介绍了基本用法的基础上 ...

  7. Java的多线程机制系列:不得不提的volatile及指令重排序(happen-before)

    一.不得不提的volatile volatile是个很老的关键字,几乎伴随着JDK的诞生而诞生,我们都知道这个关键字,但又不太清楚什么时候会使用它:我们在JDK及开源框架中随处可见这个关键字,但并发专 ...

  8. java的锁机制

    一段synchronized的代码被一个线程执行之前,他要先拿到执行这段代码的权限,在Java里边就是拿到某个同步对象的锁(一个对象只有一把锁): 如果这个时候同步对象的锁被其他线程拿走了,他(这个线 ...

  9. Java多线程--线程安全问题的相关研究

    在刚刚学线程的时候我们经常会碰到这么一个问题:模拟火车站售票窗口售票.代码如下: package cn.blogs.com.isole; /* 模拟火车站售票窗口售票,假设有50张余票 */ publ ...

随机推荐

  1. [poj 2480] Longge's problem 解题报告 (欧拉函数)

    题目链接:http://poj.org/problem?id=2480 题目大意: 题解: 我一直很欣赏数学题完美的复杂度 #include<cstring> #include<al ...

  2. 搭建Hadoop的全分布模式

    此教程仅供参考 注意:此文档目的是为了本人方便以后复习,不适合当教程,以免误导萌新... 1.安装三台Linux2.在每台机器上安装JDK3.配置每台机器的免密码登录 (*) 生成每台机器的公钥和私钥 ...

  3. PGA和UGA内存的使用情况

    引用thomas kyte的PGA和UGA的统计内存的使用情况,用排序区不同的大小来查看pga.UGA.物理读取不同内存使用 会话1:创建测试表和测试不同排序大小 create table t as ...

  4. Android 两步搞定Fragment的返回键

    Fragment可以说是在Android开发必需要使用到技术,项目中的界面基本上都是使用Fragment来实现,而Activity只是作为Fragment的载体,但有些特殊情况下Fragment也不得 ...

  5. 浅谈贝塞尔曲线以及iOS中粘性动画的实现

    关于贝塞尔曲线,网上相关的文章很多,这里我主要想用更简单的方法让大家理解贝塞尔曲线,当然,这仅仅是我个人的理解,如有错误的地方还请大家能够帮忙指出来,这样大家才能一起进步. 贝塞尔曲线,常用到的可分为 ...

  6. CentOS7.4-btrfs管理及使用

    btrfs, B-tree File System, GPL开源文件系统, 支持CoW即读时写入. 核心特性: 多物理卷支持; btrfs可由多个底层磁盘组成 支持RAID mkfs.btrfs 命令 ...

  7. BZOJ 3277/3473 广义后缀自动机

    说实话没啥难的. 建一棵广义后缀自动机,暴力自底向上更新即可. 时间复杂度非常玄学,但据说是可以过的. 要注意每个串中相同的子串的贡献是都要加进去的,开始因为这个被坑了好久 QAQ Code: #in ...

  8. Javascript中正则的 match、test、exec使用方法和区别

    总结: match 是str调用 test和exec是正则表达式调用 test只返回true或false, exec和match的结果是相同的,返回结果比较复杂

  9. uwsgi erro

    Installing collected packages: uwsgi Running setup.py install for uwsgi: started Running setup.py in ...

  10. 紫书 例题 10-28 UVa 1393(简化问题)

    这道题是对称的 所以只算"\", 最后答案再乘以2 然后每一条直线看作一个包围盒 枚举包围盒的长宽 有两种情况会重复 (1)包围盒里面有包围盒. 这个时候就是在一条直线上 那么我们 ...