zoukankan      html  css  js  c++  java
  • 关于线程1

    第一节  进程和线程

    1.1 进程和线程

    l 程序Program

    n 程序是一段静态的代码,它是应用程序执行的蓝本

    l 进程Process

    n 进程是指一种正在运行的程序,有自己的地址空间

    l  进程的特点

    动态性

    并发性

    独立性

    n 并发和并行的区别

    u 并行:多个CPU同时执行多个任务

    u 并发:一个CPU(采用时间片)同时执行多个任务 

    • 线程Thread
      • 进程内部的一个执行单元,它是程序中一个单一的顺序控制流程。
      • 线程又被称为轻量级进程(lightweight process)
      • 如果在一个进程中同时运行了多个线程,用来完成不同的工作,则称之为多线程
    • 线程特点
      • 轻量级进程
      • 独立调度的基本单位
      • 共享进程资源   

    区别 

    进程 

    线程 

    根本区别 

    作为资源分配的单位 

    调度和执行的单位

    开    销 

    每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销。 

    线程可以看成时轻量级的进程,同一类线程共享代码和数据空间,每个线程有独立的运行栈和程序计数器(PC),线程切换的开销小。 

    所处环境 

    在操作系统中能同时运行多个任务(程序)

    在同一应用程序中有多个顺序流同时执行 

    分配内存 

    系统在运行的时候会为每个进程分配不同的内存区域 

    除了CPU外,不会为线程分配内存(线程所使用的资源是它所属的进程的资源),线程组只能共享资源 

    包含关系 

    没有线程的进程是可以被看作单线程的,如果一个进程内拥有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的。 

    线程是进程的一部分,所以线程有的时候被称为是轻权进程或者轻量级进程。 

    1.2线程定义和创建1:继承Thread类

    • Thread类是Java提供的线程顶级类,继承Thread类可快速定义线程。

    public class TortoiseThread extends Thread {
        /**
         * 线程体,线程要完成的任务,要执行的代码
         */
        @Override
        public void run() {
            while (true) {
                System.out.println("乌龟领先了,加油....." +
                        "当前线程的名称:" + this.getName() +
                        ",当前线程的优先级别:" + this.getPriority());
            }
        }
    }

    public class Test {
        public static void main(String[] args) {        
            //创建一个线程
            TortoiseThread thread = new TortoiseThread();        
            //启动一个线程
            //thread.run();//这不是在启动线程,是在调用方法run()
            //启动线程,不见得立刻执行,而是进入就绪队列,等待获得CPU
            thread.start();        
            //兔子也在跑,此处不在单独创建线程并启动
            while(true){
                System.out.println("兔子领先了,add oil....,当前线程名称:"
              +Thread.currentThread().getName()+",当前线程的优先级别:"
              +Thread.currentThread().getPriority());    
            }        
        }
    }

    • run() 线程体,线程要完成的任务
    • start() 启动线程,线程进入就绪队列,等待获取CPU并执行
    • 之前讲解的程序都是单线程的
  • 相关阅读:
    C#如何通过NCO3.0来连接SAP并调用SAP中的RFC
    .Net连接到SAP【转载】
    将博客搬至CSDN
    Apache Flume 简介
    日志收集以及分析:Splunk
    《淘宝技术这十年》读后感
    python参考手册--第9章
    Hadoop将过时了?
    pythn BeautifulSoup
    Python性能鸡汤
  • 原文地址:https://www.cnblogs.com/vincentmax/p/14245925.html
Copyright © 2011-2022 走看看