并发及Java中线程的基本知识

并发模块的类型

  1. 进程:
    私有空间,彼此隔离
    拥有整台计算机的资源
    进程之间通过消息传递相互协作
    一般来说,进程=程序=应用

  2. 线程:
    程序内部的控制机制
    隶属于进程
    程序共享、内存共享

从Java中开启一个线程的方法

  1. 从Thread中派生子类
    A extends Thread
    重写其中的run方法
    再使用 new A().start() 调用线程

  2. 从Runable接口构造Thread对象
    Implements Runable
    重写run方法
    再使用 new Thread(new A()).start() 调用线程

线程的交错和竞争

  1. 时间分片:
    每个时刻只能执行一个线程
    通过时间分片,多个线程共享处理器
    由操作系统调度
  2. 线程间共享内存
  3. 竞争条件:
    程序的正确性(后置条件和不变量)取决于A和B执行的相对顺序,则称A和B产生竞争
    原子操作
  4. 消息传递:
    每次的信息(请求)被放在一个队列中,每次处理一个请求。但在处理请求时,请求发送方不会停止工作,故会产生在信息传递时间上的交错
    不能解决竞争条件问题
  5. 难以测试和调试
  6. 调用某些方法来主动影响线程之间的交错关系
    Thread.sleep() 将某个线程休眠,其他线程得到执行机会
    sleep休眠的线程不会失去对现有的锁的所有权
    t.interrupt() 从其他线程向线程t 发送中断信号
    线程在正常执行的过程中收到中断信号,可能不会理会
    若在休眠前进收到中断信号,则会抛出异常
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值