.

多核和多CPU编程介绍

一、多核和多CPU

计算机技术的发展,对CPU的要求越来越高,各大厂商通过不断的挖掘CPU的频率通过类似超标量的方法等来实现对芯片性能的极致榨取。但是随着实际场景对CPU性能的需求不断增长,单一核心CPU的性能提高已经无法实现摩尔定律的发展指标。所以,包括Intel和AMD等CPU生产厂商,开始在一个芯片中,集中多个CPU计算核心。这也是在计算机的说明中,某个芯片支持4核、8核等等的情况。同样,为了提供更高的性能,可以在主板上集成多个CPU。而实际上,多CPU比多核出现的要早得多。多核心的CPU技术发展以及集成多个CPU,仍然无法满足一些具体的应用场景,比如大规模的电商应用、电子交易、海量在线聊天等,在这种情况下,分布式的应用被提出并被广泛应用,在分布式的场景下,也可以看成更高一层的多CPU编程。也就是说到现在为止,可以把多核心和多CPU简单抽象出来,在这种硬件基础上的编程,就可以正式的展开分析了。

二、并行编程和并发编程

面对多核和多CPU编程在实际的场景中映射到编程模式就是并行编程和并发编程。对普通程序员来说,并发编程几乎是每个程序员都熟知的。当然,对大多数程序员来说,并发编程都是一个痛点中的痛点。对大多数人来说,多年积累的生活常识,几乎都是串行的,也就是干完一件事儿,再干一件事儿。但为了榨取CPU的全部算力,不给CPU片刻休息的机会,就需要让多个线程(进程)监视着CPU,一有闲暇,就立刻抢过来运算。在单核心时代,多线(进)程编程就已经流行了。但这也带来了多线程之间如何切换的时机、资源的互斥处理等等诸多问题。而多核心的出现,又提出了更高的要求,特别是从单核心的模拟并行,发展到了真正并行。思想的转变是一个非常困难的过程,要把原来的互斥、资源访问等上升到一个更高的抽象层次。同时,要从算法思想上对任务进行分解,能不能实现真正的任务同时展开也即并行进行。实现真正的串行编程到并行编程的的转变。这其中,不但要对原来的数据结构、编程技术进行完善升级,还要对并行理论和相关的技术实现深入了解。同样,对应到分布式中的多核和CPU编程同时存在,这也是一个更复杂的问题,需要引起更大的重视。不同的场景下,如何更好挖掘计算机整体(包括集群)的性能,才是设计的最终目的。也就是说,就是通过设计实现任务的分解,达到并行,减少并尽量杜绝CPU饥饿,尽量减少任务的并发冲突并能够让自己的程序实现动态的弹性扩展,实时的适应当前的整体的计算机的性能表现。通过上述的分析可以简单把其分成三类:1、单核多线程程编程(单核心)2、多核多线程编程(多核心)3、多机分布式编程(多CPU)

三、实际场景的应用及涉及到的具体问题

并行编程和并发编程经常可遇到的实际场景有:1、大规模社交场景2、大规模游戏3、海量数据计算4、海量数据存储5、电商及电子支付其它如科学计算等还有很多应用场景,在常见的RPG游戏中,比如帝国时代、红警等,为什么不能爆更多的游戏单元,其实就是和CPU的计算能力有很大的关系。而涉及到的具体问题主要有:1、并发到并行的挑战2、复杂任务的分解和调度3、架构和设计思想的挑战4、数据结构和扩展性在后面,就针对这些问题,具体的展开分析说明。

四、总结

计算机的出现,是人类历史上一次重大的技术进步,也被称之为信息革命。但是,在信息时代,虽然人人都知道计算机的重要,生活中到处都无法离开计算机,但真正知道信息应用的瓶颈在哪儿的,怎么能更好的挖掘信息技术的载体——计算机的潜力的,却不为广大人为所知。即使是很多参与信息技术甚至计算机技术的所谓开发人员,对此也是知之甚少。正如很多业内同行所言,计算机行业是一个入门门槛比较低的行业,很多其它专业甚至一些社会培训机构的人经过简单培训就进入到这个领域并可以拿到比较高的薪水,这也是一种实际的存在。越是如此,越是能显示出真正的开发人员的重要性,国内的35岁现象,其实就是对上述实际情况的一种反噬。真正的把计算机技术搞到深入的,无论哪种技术,包括最常见的各种语言开发、硬件开发,包括最近很火的深度学习,其实都是一种应用手段,是一种把实际问题,通过计算机来高效实现的过程。在这其中,多核和多CPU的编程技术只是计算机开发的一个方向而已,通过复杂手段进行简单实现,通过简单设计来实现复杂应用,这就是矛盾论的一种具体和集中的表现。

预览时标签不可点收录于话题#个上一篇下一篇


转载请注明:http://www.abachildren.com/xgyy/218.html