设计的架构。
我们的目标是科学计算,是国之重器,追求的不是高可用、易维护,而是极致,是压榨出硬件最后一丝性能的极致效率。”
话音落下,整个会议室鸦雀无声。
周振华脸上的笑容僵住了。
刘毅的脸色微微一变。
许燃没有看他们,他转身面对白板,手中记号笔的笔盖被“啪”一声拔开。
他没有直接说刘毅的方案哪里不好,而是提出了第一个问题。
“第一个问题,数据结构。
你的方案里完全没有提。
我要知道,飞机表面被离散成上亿个网格点,这些数据在内存中如何组织?
你考虑过cpU的缓存行对齐来避免伪共享问题了吗?”
“嗡!”
刘毅的脑袋里像是被狠狠敲了一下。
缓存行对齐?
伪共享?
瞬间刺破了他方案华丽架构的外壳!
这是只有最顶尖的高性能计算专家,在进行底层优化时才会去死磕的细节!
对于习惯了应用层开发的程序员来说,这几乎是知识盲区!
他引以为傲的微服务、docker,在这些底层硬件效率问题面前,听起来像个笑话。
冷汗瞬间从他的额角渗了出来。
不等他回答,许燃的第二个问题接踵而至。
“第二个问题,多线程模型。
你说用c++,无非就是用标准库里的std::utex或者std::lock_guard来给共享数据加锁。
但我们的计算场景,是典型的多生产者-单消费者模型。
每次加锁解锁,都意味着用户态到内核态的切换,会带来多大的上下文开销?
为什么不用基于cAS原子操作的无锁队列?”
如果说第一个问题只是让他震惊,第二个问题就让他感到了恐惧!
无锁编程!
这在程序员的世界里,堪称金字塔尖的屠龙之技!
难度极高,稍有不慎就会导致逻辑崩溃,但一旦成功,带来的性能提升是碾压性的!
这个搞应用数学的,怎么会对计算机并发编程的底层原理,理解到这种妖孽的程度?
会议室里,几位教授的脸色已经变了,他们看着许燃的背影,眼神里
温馨提示:亲爱的读者,为了避免丢失和转马,请勿依赖搜索访问,建议你收藏【笔趣库网】 m.biquku8.com。我们将持续为您更新!
请勿开启浏览器阅读模式,可能将导致章节内容缺失及无法阅读下一章。