多线程,进程和ReentrantLock

线程、进程

进程
+ 一个进程包括由操作系统分配的内存空间,一个程序至少有一个进程,一个进程至少有一个线程;
+ 一个线程不能独立的存在,它必须是进程的一部分;一个进程一直运行,直到所有的非守护线程都结束运行后才能结束;
+ 相当于打开一个黑框,只能运行.exe文件、

   Runtime.getRuntime().exec("D://ProgramFiles//Tencent//QQ//Bin//QQScLauncher.exe");

并行和并发
+并行
++多个CPU实例或者多台机器同时执行一段处理逻辑,是真正的同时;
+并发
++通过CPU调度算法,让用户看上去同时执行,实际上从CPU操作层面上不是真正的同时;

线程
+线程带着任务去找CPU;
+其他的线程由主线程创建
//线程休眠,单位毫秒
Thread.sleep(100);
//看看现在的进程
Thread.currentThread( );
//一个锁
synchronized( ){ }
//要在锁里面用,唤醒
c.notify();
//要在锁里面用,等待
c.wait();
Java中的实现方法
1、对Thread类的继承,并重写run方法
2、通过实现Runnable接口来创建
线程安全、线程不安全
安全线程:在并发的情况下,代码经过多线程使用;线程的调度顺序不影响最终结果
StringBuffer;HashTable
线程安全但效率低
不安全线程:在并发情况下,代码结果多线程使用;线程的调度顺序影响最终结果
StringBuilder;HashMap
线程不安全但效率高

线程的生命周期

新建
new
就绪
runnable
运行
running
阻塞
blocked
死亡
dead

ReentrantLock:以前已经写过了,直接见下面链接
链接: link.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值