用标准库写出来的就是最好性能了,基础的工作runtime和库都做了,拿来就能写应用,基础设施不用操心。如果你发现标准库或者runtime做得不够好,你有性能更高的做法,那可以提patch,整个社区都受益。
golang是一编译型的强类型语言,它在开发上的高效率主要来自于后发优势,不用考虑旧有恶心的历史,又有一个较高的工程视角。良好的避免了程序员因为“ { 需不需要独占一行 ”这种革命问题打架,也解决了一部分趁编译时间找产品妹妹搭讪的阶级敌人。
它有自己的包管理机制,工具链成熟,从开发、调试到发布都很简单方便;
有反向接口、defer、coroutine等大量的syntactic sugar;
编译速度快,因为是强类型语言又有gc,只要通过编译,非业务毛病就很少了。【感兴趣的话点击此处,了解一下】
有以下方法:方法一:使用带有缓冲的channel的特性
直到缓冲区被填满后,写端才会阻塞。
缓冲区被读空,读端才会阻塞。
代码中channel数据结构为什么定义struct?
因为空结构体变量的内存占用大小为0,而bool类型内存占用大小为1,这样可以更加最大化利用我们服务器的内存空间。
方法二:使用sync.WaitGroup
WaitGroup对象内部有一个计数器,最初从0开始,它有三个方法:Add(),Done(),Wait()用来控制计数器的数量。
欢迎分享,转载请注明来源:夏雨云
评论列表(0条)