Java线程初探


1、线程是什么?

1.1线程

线程是一条执行路径,是程序执行时的最小单位,它是进程的一个执行流,是CPU调度和分派的基本单位,一个进程可以由很多个线程组成,线程间共享进程的所有资源,每个线程有自己的堆栈和局部变量。线程由CPU独立调度执行,在多CPU环境下就允许多个线程同时运行。同样多线程也可以实现并发操作,每个请求分配一个线程来处理。

1.2区别于进程

进程是资源(CPU、内存等)分配的基本单位,它是程序执行时的一个实例。程序运行时系统就会创建一个进程,并为它分配资源,然后把该进程放入进程就绪队列,进程调度器选中它的时候就会为它分配CPU时间,程序开始真正运行。

一个正在运行的软件(如下载软件)就是一个进程,可以的同时运行多个进程(比如同时打开一个视频播放软件和一个下载软件),一个进程可以同时运行多个任务( 下载软件可以同时下载多个文件,每个下载任务就是一个线程), 可以简单的认为进程是线程的集合。

线程是一条可以执行的路径。多线程就是同时有多条执行路径在同时(并行)执行。

2、为什么要使用线程

2.1、发挥多核CPU的优势

单核CPU上所谓的"多线程"是假的多线程,同一时间处理器只会处理一段逻辑,只不过线程之间切换得比较快,看着像多个线程"同时"运行罢了。多核CPU上的多线程才是真正的多线程,能让多段逻辑同时工作,多线程,可以真正发挥出多核CPU的优势来,达到充分利用CPU的目的。如果是单线程的程序,那么在双核CPU上就浪费了50%,在4核CPU上就浪费了75%。

2.2、防止阻塞

从程序运行效率的角度来看,单核CPU不但不会发挥出多线程的优势,反而会因为在单核CPU上运行多线程导致线程上下文的切换,而降低程序整体的效率。但是单核CPU还是可以应用多线程,起到防止阻塞的作用。如果单核CPU使用单线程,那么只要当前线程阻塞了,比方说远程读取某个数据,对端迟迟未返回又没有设置超时时间,那么你的整个程序在数据返回回来之前就停止运行了。多线程可以防止这个问题,多条线程同时运行,哪怕一条线程的代码执行读取数据阻塞,也不会影响其它任务的执行。
什么是线程的上下文切换
举个例子,假设目前接水房(视为一个cpu)有四个水管(视为一定的cpu资源)可以接水,我如果用4个桶分别对应4个水管,那么就比较完美,如果少一个则闲置一个,多一个则会出现抢占。如果此时我的水桶个数大于水管数,为了每个桶都有水,我们就需要切换水桶,这个过程实际上就是线程的上下文切换。

2.3、便于建模

假设有一个大的任务A,单线程编程,那么就要考虑很多,建立整个程序模型比较麻烦。但是如果把这个大的任务A分解成几个小任务,任务B、任务C、任务D,分别建立程序模型,并通过多线程分别运行这几个任务,就会简单很多了。

3、java多线程实现的几种方式

  1. 继承Thread类,重写run方法
  2. 实现Runnable接口,重写run方法
  3. 通过Callable和FutureTask创建线程
  4. 通过线程池创建线程

目前只用到前面两种方式,以下用代码进行说明

方式一、继承Thread类,重写run方法

public class MyThread extends Thread{
    public MyThread(){
        //编写子类的构造方法,可不写
    }
    public void run(){
        //将自己的线程代码写在此处
        System.out.println(Thread.currentThread().getName());
    }
    public static void main(String[] args){ 
        MyThread mythread = new MyThread(); 
        mythread .setName("自定义线程");
        mythread .start(); //通过调用start方法启动线程;      
        System.out.println(Thread.currentThread().toString());  
    }
}

方式二、通过实现Runnable接口,实现run方法

public class Myhread {

    public static void main(String[] args){ 
        System.out.println(Thread.currentThread().getName());
        Thread mythread = new Thread(new MyThread());
        mythread.start(); 
    }
}

class MyThread implements Runnable{
    @Override
    public void run() {
        // TODO Auto-generated method stub
        System.out.println(Thread.currentThread().getName()+"-->我是通过实现接口的线程实现方式!");
    }   
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值