zoukankan      html  css  js  c++  java
  • 【Java学习笔记】线程学习笔记

    一、资源

       http://blog.csdn.net/axman/article/details/431796

       这个博客里有Java多线程、线程池的一系列,从基础开始就很清楚,牛人

    二、重点

      今天读到了基础篇(三),跳过了后面的方法介绍,以后估计还得补上来的....

      做笔记......

      1、线程对象和线程

         线程对象:一个Object类,线程执行形式的封装

         线程:真正执行的那什么..

      2、JVM到底做了什么?

          " JVM进程被启动,在同一个JVM进程中,有且只有一个进程,就是它自己.然后在这个JVM环境中,

    所有程序的运行都是以线程来运行.JVM最先会产生一个主线程,由它来运行指定程序的入口点.在这个
    程序中,就是主线程从main方法开始运行.当main方法结束后,主线程运行完成.JVM进程也随之退出.
        我们看到的是一个主线程在运行main方法,这样的只有一个线程执行程序逻辑的流程我们称
    之为单线程.这是JVM提供给我们的单线程环境,事实上,JVM底层还至少有垃圾回收这样的后台线程以
    及其它非java线程,但这些线程结我们而言不可访问,我们只认为它是单线程的."

      3、并行和并发

        并行:单CPU中,通过调度在线程直接切换

        并发:  多CPU中,同时让两个以上线程同时运行

        疑惑1:我的理解:单行时其实某一时间点上只有一个线程在跑?

        疑惑2:我的理解:等于某个时间点可以有多个线程跑?那系统的进程和线程是什么关系?一个进程类似于一个程序的运行空间,而线程则是进程里的某些任务的执行通道?

      4、thread.start()

    •       你只要调用start()方法,JVM就会管理这个线程对象让它产生一个线程并注册到线程处理系统中(线程栈).
    •       start()方法最本质的功能是从CPU中申请另一个线程空间来执行run()方法中的代码,它和当前的线程是
        两条线,在相对独立的线程空间运行,也就是说,如果你直接调用线程对象的run()方法,当然也会执行,但
        那是在当前线程中执行,run()方法执行完成后继续执行下面的代码.而调用start()方法后,run()方法的
        代码会和当前线程并发(单CPU)或并行(多CPU)执行.         
    •       一个Thread的实例一旦调用start()方法,这个实例的started标记就标记为true,事实中不管这个线程
        后来有没有执行到底,只要调用了一次start()就再也没有机会运行了,这意味着:
          [通过Thread实例的start(),一个Thread的实例只能产生一个线程]

               

       public synchronized void start() {
    if (started)
    throw new IllegalThreadStateException();
    started
    = true;
    group.add(
    this);
    start0();
    }

      5、thread(new Runanle()).start()

          一个Runnable实例给Thread对象多次包装,我们就可以看到它们实际是在同一实例上启动线程

          例子在资源博客http://blog.csdn.net/axman/article/details/420892

          我的理解:

            这里很奇怪我觉得,

               R r = new R();

             for(int i=0;i<10;i++) {
                 new Thread(r).start();
              }

            虽然每次都是 new Thread(r).start(),但是按照博客的说法,应该是在一个线程,那这说明了线程对象和线程的区别,每次新建的线程对象肯定是不一样的,但是他们启动的线程是一样的,是这样理解的么?

  • 相关阅读:
    服务器/服务器架构/阿里云服务器/虚拟机
    第十五章、线程之协程
    第十五章、线程池和进程池
    第十五章、线程之queue模块的各种队列
    第十五章、Python多线程之信号量和GIL
    第十五章、Python多线程同步锁,死锁和递归锁
    第十五章、并发编程之守护线程
    第十五章、并发编程之线程
    抢票小程序
    队列与生产者消费者模型
  • 原文地址:https://www.cnblogs.com/hundan/p/2166086.html
Copyright © 2011-2022 走看看