大家好,我是小风(人设建立中。。。),今天给大家带来一篇胜似技术文的非技术文。
最近陆陆续续写了几篇关于CPU的文章,可能有的同学会问,程序员写代码就好了,为什么需要去理解CPU啊?不嫌累啊?啊?啊?你倒是说啊。
计算机系统 != 汉堡包
在之前的文章中我把计算机系统比作一个汉堡包,这个类比不太恰当,虽然汉堡包是层级结构,但它是上下对称的,计算机系统的层级结构显然不是对称的,你要说披萨还差不多,注意是披萨,不是馅饼,因为馅饼也是对称的。
计算机系统的结构是上层基于下层,并且上层对外屏蔽下层,因此用洋葱来比喻计算机系统是再恰当不过了,这两者都是层级结构,下层对上层都不可见,最妙的是,这两者看时间长了都会辣眼睛!
这种层级结构保证了处于上层程序员无需理解下一层。
模糊的精确
你的确不需要知道底层全部的微观细节,实际上我也不相信有谁能全部知道,如果你太注重细节,没有对计算机系统的大局观而是一头扎到细节里,最终也只是徒劳,只挖掘细节很像是一种“模糊的精确”。
精确的模糊
但是,如果你能知道底层的宏观上的原理,情况就不一样了,我把这种宏观上的不那么细节的理解称之为“精确的模糊”,老外有一个词我认为很贴切:The Big Picture。
程序员这一行,个人认为精确的模糊要远好于模糊的精确,因为前者要想进一步了解细节是很容易的(只是需不需要的问题),反之则非常困难。而且依靠这种精确的模糊已经能解决很多问题,而后者则不能。
上帝视角
每一个大家认为的高手脑海里都有这样一种精确的模糊(或者精确的精确,高手中的高手),ta可能不知道编译器(解释器)、链接器、操作系统、网络协议栈、CPU、内存等等所有核心模块的全部细节,但是ta知道这些模块“应该”怎样工作,当你有了这种理解后,你会发现:
你很确定的自己的每一行程序是怎么被计算机执行的;你清楚的知道什么时候该用多线程什么时候不该用;你清楚的知道自己的线程什么时候该加锁、什么时候该等待,怎样解决互斥问题,怎样解决同步问题;你清楚的知道自己的每一段代码大概可能会执行多长时间;你清楚的知道自己的每次函数调用从上层到底层是如何执行的,因此你很清楚该选择使用什么样的函数,传递什么样的参数才能达到自己想要的效果;你清楚的理解计算机系统,因此发现公众号码农的荒岛求生也就是刚刚在本文开头立人设的小风说的都是你已经知道的东西。
当你的程序出现问题后无头苍蝇般瞎试一通并期待自己的程序能奇迹般正常工作时;当编译器提示奇怪的错误时;当链接器莫名其妙的提示'undefined reference to ***'时;当程序运行起来就core时;当程序运行一段时间被OOM kill掉时;当你的程序内存泄漏时;当你的程序莫明奇妙耗时非常高时;如果在这些时刻你能做的仅仅是等待别人来帮忙,那么就不要说程序员不需要理解底层了。
说了这么多,用一句话说就是理解底层的好处可以让程序员在写程序时获得“上帝视角”,一切都逃不过你的法眼。
本文转载自微信公众号「码农的荒岛求生」,可以通过以下二维码关注。转载本文请联系码农的荒岛求生公众号。