一、多线程。

    1、进程:一个正在执行的程序叫做进程。
          每一个进程的执行都有一个执行顺序,这个顺序就是一个执行的路径,或者叫做一个控制单元。

    2、线程:就是上述进程中的一个独立控制单元, 线程在控制着进程的执行。
          一个进程至少有一个线程。

      Java virtual machine 启动时会有一个进程 Java.exe, 该进程中至少有一个进程负责Java程序的执行,
      而此进程运行的代码存在于 main方法中。
      而该线程称之为主线程。

    扩展:在更细节的说明jvm, jvm启动的时候不止主函数一个线程在进行, 还有Java垃圾回收机制的线程。

二、如何在自定义的代码中, 定义一个多线程呢?

    Java中对于线程这类事物进行了描述, 并封装成 Thread类,

  要创建一个线程有两种方法:

    创建线程的第一种方法: 就是继承至 Thread 类
                  步骤:1、定义一个类,继承Thread类。
                     2、复写类中的run方法。
                              为了定义线程要执行的代码。
                     3、new一个新的对象,创建线程。
                       4、调用其start方法,
                              该方法有两个作用:1)、启动线程 2)、调用run 方法。

                  此时main函数中的程序和 run中的程序同时进行。

          实操结果:发现每次执行的结果都不一样, 这是因为多个线程在获取cup的资源, CPU执行到那个线程,哪个线程就开始运行。
                而且每一时刻CPU中都只在运行一个进程(线程),CPU在做高速切换。 此切换具有

                所以:随机性是多线程的一个特点。

          在子程序中重写run方法的原因: 因为Thread类是为了描述一个线程, 所以该类就有一个功能: 即存储要执行的代码。
          该功能就是就是run()方法。 就是说:run()方法中的代码就是线程执行的代码(类似于main)。

          注意:只有在多线程开启语句执行了过后才会有多线程执行(start语句之后才开启多线程)。

    创建线程的第二种方法: 就是声明实现一个Runnable接口。

                  步骤:1、定义一个类,其实现了Runnable接口,
                                  class Test implements Runnable
                     2、复写该类中实现Runable而来的run方法。
                                  确定线程中应执行代码:public void run(){}
                       3、new一个该类的新对象 t。
                                  Test t = new Test();
                       4、new一个Thread 方法,并将 对象 t 当做构造实参传进去(即指定线程要执行的run方法)。
                                  Thread th = new Thread(t);
                       5、调用该Thread 对象的start方法,
                                  th.start();

          继承方式和实现方式的区别:

             实现方式: 避免了单继承带来的局限性, 在定义多线程的时候, 建议使用实现方式。
                   其线程代码存放在接口子类对象的run方法中。(只要传入Thread的对象相同,可以实现多线程共同执行同一份代码)

             继承方式:其线程代码存放在Thread子类的对象run方法中, 一个线程只能执行自己的run中的代码。

三、线程中的方法

      1、Thread 中,定义了一个name私有的String类型的变量,在new Thread对象的时候可以传入字符串名称,

                  (注:在创建子类对象的时候要复写构造函数 super())
            使用getName()方法可以拿到这个变量。

            其实线程有默认的名称: 就是Thread-编号, 该编号从 0 开始。

        static Thread currentThread():获取当前线程的对象。
        getName():获取线程的名称。 而设置线程 的名称: setName(), 或者构造函数。

四、多线程中的安全问题

    问题原因:是因为多个线程在操作同一个共享数据时(实现方法操作同一个对象, 或继承方法操作一个静态数据),其中某条线程只执行了一部分,没有执行完,
          另一个线程就进来参与执行,就发生共享数据错误。

    解决方法:在多个线程操作同一个共享数据时,同时只让一个线程对数据进行操作,该过程中,其它线程不能参与执行。

    Java对线程的安全问题提供了专业的解决工具:

        1、同步代码块:
                synchronized(对象)
                {
                    需要被同步的代码(这里就是数据代码);
                }
          这里的 对象 是任意对象,如同一个 锁,只有持有锁的线程才能同步执行数据代码;
         没有锁的进程,即使拿到了cpu 的执行权,也不能执行数据代码。(例子:火车上的卫生间--老毕例子)

          好处:必须保证同步中只能有一个线程在运行。
          弊端:降低了程序效率。

        2、非静态同步函数:

            就是将synchronized关键字放在函数的修饰符位置。

            for example: synchronized void run(){} (注:一般不能同步run方法,此处只为举例。)

          同步函数的“锁”(对象)是调用这个方法时的对象, 即:相当于 this

        3、静态同步函数:
            如果上述同步函数是被静态(static)修饰的,
            其静态“锁” 就是调用这个方法的类的字节码对象, 即: 类名.class【类型为Class】

          (因为该静态方法进内存时,没有该类的对象,但是却有该类的 字节码对象,使用该字节码对象为同步锁)

        同步的前提:1、有两个以上的线程在执行同一份代码,
              2、它们使用了同一把锁。

五、死锁

    出现原因: 同步 中 嵌套 同步,且同步的锁不一样。(避免此情况出现)。

多线程(Thread,Runnable)的更多相关文章

  1. android 多线程Thread,Runnable,Handler,AsyncTask

    先看两个链接: 1.http://www.2cto.com/kf/201404/290494.html 2. 链接1: android 的多线程实际上就是java的多线程.android的UI线程又称 ...

  2. 第39天学习打卡(多线程 Thread Runnable 初始并发问题 Callable )

    多线程详解 01线程简介 Process与Thread 程序:是指令和数据的有序集合,其本身没有任何运行的含义,是一个静态的概念. 进程则是执行程序的一次执行过程,它是一个动态的概念.是系统资源分配的 ...

  3. java 多线程--- Thread Runnable Executors

    java 实现多线程的整理: Thread实现多线程的两种方式: (1)继承 Thread类,同时重载 run 方法: class PrimeThread extends Thread { long ...

  4. [java多线程] - Thread&Runnable运用

    负载是一个很大的话题,也是一个非常重要的话题.不管是在大的互联网软件中,还是在一般的小型软件,都对负载有一定的要求,负载过高会导致服务器压力过大:负载过低又比较浪费服务器资源,而且当高请求的时候还可能 ...

  5. Java多线程高并发学习笔记(一)——Thread&Runnable

    进程与线程 首先来看百度百科关于进程的介绍: 进程是一个具有独立功能的程序关于某个数据集合的一次运行活动.它可以申请和拥有系统资源,是一个动态的概念,是一个活动的实体.它不只是程序的代码,还包括当前的 ...

  6. JAVA多线程Thread VS Runnable详解

    要求 必备知识 本文要求基本了解JAVA编程知识. 开发环境 windows 7/EditPlus 演示地址 源文件   进程与线程 进程是程序在处理机中的一次运行.一个进程既包括其所要执行的指令,也 ...

  7. 多线程-Thread、Runnable 创建线程和调用过程分析

    创建线程的两种方式: 1:创建Thread类的子类 ---基于继承的技术 . 2:以Runnable接口实例为构造参数直接通过new  创建 Thread 实例.---基于组合的技术. public ...

  8. 多线程-----Thread类与Runnable接口的区别

    第一个继承Thread类来实现多线程,其实是相当于拿出三件事即三个卖早餐10份的任务分别分给三个窗口,他们各做各的事各卖各的早餐各完成各的任务,因为MyThread继承Thread类,所以在newMy ...

  9. java中多线程中Runnable接口和Thread类介绍

    java中的线程时通过调用操作系统底层的线程来实现线程的功能的. 先看如下代码,并写出输出结果. // 请问输出结果是什么? public static void main(String[] args ...

  10. 多线程 Thread.yield 方法到底有什么用?

    概念 我们知道 start() 方法是启动线程,让线程变成就绪状态等待 CPU 调度后执行. 那 yield() 方法是干什么用的呢?来看下源码. /** * A hint to the schedu ...

随机推荐

  1. 保留最新N份备份目录脚本

    如下所示,在/opt/backup下是备份目录,只需要保留最新的三份备份,在此之前的备份目录都要删除. [root@syslog-ng ~]# cd /opt/backup/ [root@syslog ...

  2. Spring RPC 入门学习(3)-获取Student对象

    Spring RPC传递对象. 1. 新建RPC接口:StudentInterface.java package com.cvicse.ump.rpc.interfaceDefine; import ...

  3. HashMap和HashTable区别【转载】

    今天看到的HashMap和HashTable区别介绍,收藏留着学习. 出处:http://www.importnew.com/24822.html 代码版本 JDK每一版本都在改进.本文讨论的Hash ...

  4. Linux内核第六节 20135332武西垚

    如何描述一个进程:进程描述符的数据结构: 如何创建一个进程:内核是如何执行的,以及新创建的进程从哪里开始执行: 使用gdb跟踪新进程的创建过程. 进程的描述 操作系统三大功能: 进程管理(最核心最基础 ...

  5. HanderBar

    对于java开发,涉及到页面展示时,比较主流的有两种解决方案: 1. struts2+vo+el表达式. 这种方式,重点不在于struts2,而是vo和el表达式,其基本思想是:根据页面需要的信息,构 ...

  6. Leetcode——66.加一

    @author: ZZQ @software: PyCharm @file: leetcode66_加一.py @time: 2018/11/29 16:07 要求:给定一个由整数组成的非空数组所表示 ...

  7. wordpress升级出错

    服务器是腾讯云 搜索到的解决方案有几个,试了好几个,不知道哪个是根本原因,反正都操作了. 设置wordpress文件夹和子文件夹的权限 编辑wp-config.php,在文末添加如下: define( ...

  8. 关于pycharm的debugger配置问题(包含启用py.test测试)

    今天才发现了一个刷新三观的问题.那就是 pycharm的底层集成的debugger功能其实是依赖于几个测试框架.. 现在由于要写基于pytest的测试,但是如果到zsh里面去跑命令,明显是效率很低下的 ...

  9. XML的基礎結構

    1.xml是什麼? xml,Extensible Markup Language,扩展性标识语言,後綴名為.xml. 2.xml有什麼功能? xml功能是傳輸和儲存數據,用於不同的應用和平台數據共享和 ...

  10. js break和continue

    break的兩種形式: break:未加標籤,適用於switch和循環結構 break labelname:適用於任何代碼塊: continue的兩種形式: continue:適用於循環結構 cont ...