线程基础与线程之间的共享和协作

基础概念

 

  • CPU核心数和线程数的关系

 

对于一个CPU,线程数总是大于或等于核心数的。一个核心最少对应一个线程,但通过超线程技术,一个核心可以对应两个线程,也就是说它可以同时运行两个线程。

 

  • CPU时间片轮转机制

 

又称RR调度,会导致上下文切换

 

  • 什么是进程和线程

 

进程:程序运行资源分配的最小单位,进程内部有多个线程,会共享这个进程的资源

线程:CPU调度的最小单位,必须依赖进程而存在。

 

  • 澄清并行和并发

 

并行:同一时刻,可以同时处理事情的能力

并发:与单位时间相关,在单位时间内可以处理事情的能力

 

  • 高并发编程的意义、好处和注意事项

 

好处:充分利用cpu的资源、加快用户响应的时间,程序模块化,异步化

 

风险:1、安全性问题:主要是多个线程共享数据时可能会产生于期望不相符的结果

2、活跃性问题(liveness):当某个操作无法继续进行下去时,就会发生活跃性问题。比如死锁、饥饿、活锁等问题。

3 性能问题

a.线程过多时会使得CPU频繁切换,花在调度上时间太多。

b.多线程环境必须使用同步机制,导致很多编译器想做的优化被抑制。

c.线程过多还会消耗过多内存

 

java里的线程

 

java里的程序天生是多线程

 

// 获取 Java 线程管理 MXBean ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean(); //不需要获取同步的 monitor 和 synchronizer 信息,仅获取线程和线程堆栈信息 ThreadInfo[] threadInfos = threadMXBean.dumpAllThreads(false, false); //遍历线程信息,仅打印线程id和线程名称信息 for (ThreadInfo threadInfo : threadInfos) { System.out.println("[" + threadInfo.getThreadId() + "] " + threadInfo.getThreadName()); }

 

 

 

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值