不知道为什么,我很厌恶 map()

查看 27|回复 4
作者:levelworm   
首先声明一下,我承认我是个很烂的程序员。我甚至不愿意承认自己是程序员。(也许这就是原因?)
因为公司转向 Flink ,所以今天决定学习一下。但是不知道为什么,看到 map()就觉得生理上的厌恶,和看见一只蟑螂一样。
其实我自己也不能理解这种厌恶--我能理解为什么自己不喜欢,因为 map()本身没有可读性,你看到这个,就得去里头看到底是调用了什么函数。但是我不知道为什么我会有生理上的厌恶。同理,我在 PySpark 里看到 map(),也会极其厌恶,尤其是配合 lambda 食用,则更加厌恶。比如说
result = map(lambda x: x["id"], data["item"])
看到一次我就恶心一次。
不知道有没有类似的朋友,你们是如何克服的?我看了一下,Flink 里似乎无法避免 map()。所以只能自己习惯了。

map, 厌恶, flink

iintothewind   
那是因为你用的 Python, 强类型动态语言, 而且传入参数没有 type hint 的原因吧.
你试试用用 Scala 不就好多了.
sagaxu   
跟你相反,我非常喜欢 map/filter/reduce/fold/chunk...,意图+操作,可读性强,且非常直观
levelworm
OP
  
@sagaxu #2
问题在于,map()意图清晰在哪里?只是知道要做个变换,具体是什么还得看里头啊。还是说我理解错了?
好吧,也许改成 transform()我就能接受了。真是奇怪的心理。
levelworm
OP
  
@iintothewind #1
有可能,但是我觉得 Python 那段,用 list comprehension 就好很多。
您需要登录后才可以回帖 登录 | 立即注册

返回顶部