自定义线程

一、进程   

延伸:http://ifeve.com/java-concurrency-thread/

多线程比多任务更加有挑战。多线程是在同一个程序内部并行执行,因此会对相同的内存空间进行并发读写操作。这可能是在单线程程序中从来不会遇到的问题。其中的一些错误也未必会在单CPU机器上出现,因为两个线程从来不会得到真正的并行执行。然而,更现代的计算机伴随着多核CPU的出现,也就意味着不同的线程能被不同的CPU核得到真正意义的并行执行。

 

正在执行的应用程序称为一个进程。进程负责了内存空间的划分(向windows申请空间,将代码放入内存中)。

 windows多任务操作系统:

   宏观:同时运行多个应用程序

   微观:cpu做了一个快速切换的执行动作,由于速度太快,感受不到。

单核cpu:在一个时间片内只能执行一个应用程序。

各个应用程序其实是在做cpu的资源争夺。

二、线程

线程在一个进程中负责了代码的执行,就是进程中的一个执行路径。

多线程:在一个进程中有多个线程同时在执行不同的任务。

运行任何一个Java程序,jvm在运行的时候都会创建一个main线程执行main方法中所有代码。

 

一个Java应用程序至少有几个线程?  

   至少两个,一个是主线程负责main方法代码的执行,一个是垃圾回收器线程负责回收垃圾。

 

多线程的好处:  延伸参考:http://ifeve.com/benefits/

     1.解决了一个进程能同时执行多个任务的问题;

     2.提高了资源的利用率。

ps:

为什么等待数据下载的过程中CPU将会空闲大量时间?

计算机硬件上使用DMA来访问磁盘等IO, 请求发出后CPU就不再管了,直到DMA处理器完成任务,再通过中断告诉CPU完成了。I/O阻塞了CPU时间就交给其它线程和进程了。虽然IO不会占用大量的CPU时间,但是非常频繁的IO还是会非常浪费CPU时间的.

多线程的弊端:  延伸参考:http://ifeve.com/costs-of-multithreading/

  1.增加了cpu的负担

  2.降低了一个进程中线程的执行概率。

  3.引发了线程安全问题

  4.出现了死锁现象

 

转载于:https://www.cnblogs.com/thiaoqueen/p/6557628.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值