以前一直用的python,最近想做个利用web浏览器作为前后处理view层的有限元分析软件的小项目,想着计算效率可能会成为一个瓶颈,而且每次十多万的整数和浮点数传输不可能用文本格式,想用websocket。正好python也快用吐了,用golang换换口味。

前一个月看了看golang的go语言编程,又用gin写了个简单的curd。感觉还行。

然后开始正式撸一个将 abaqus 的inp文件中的网格解析成用于显示的三角面片,用于图形显示。

整个撸代码的过程中,就像是开着一辆卡车,一路上

首先是在python中最习惯的列表的map filter reduce操作,毕竟没有泛型,我也有心里准备。

比如 python 中的一句话

ys = [x*x for x in xs if x%2==0]

golang中需要这样

ys:=make([]int,len(xs))

for _,x := range xs{

if x%2==0{

ys=append(ys,x*x)

}

}

虽然早听说golang的目标是web时代的C,但一直也没什么感触,有也只是往运行效率方面想。

直到碰到了要判断一个集合中是否包含某个元素。

在python中也就是一个 in 的事情,比如

if a in xs:

print('a in xs')

在golang中你需要手动的去遍历这个slice,然后返回true 或 false。

[mathjax]

手动遍历slice的时候自然而然就会想这个slice是不是经常要查询,需不需要先排序,把查询的复杂度从[latex]n[/latex]降到[latex]log(n)[/latex]

类似的这种还有 sort 函数等等。

突然让我感慨,golang果然不愧是web时代的C,这让我想仿佛回到用C的时候,写业务逻辑代码之前要先设计数据结构。从最基本的List还是写起,还要根据实际需求,决定这个List是单项还是双向。业务中如果经常需要查询操作,必然还要再写一个搜索二叉树,设计一个struct的时候还要考虑字节对齐的问题。

果然golang不愧是web时代的C。