这家伙连局部作用域都没有,摸索了好久
不过Io这个基于原型的语言,确实在了解Io之后,我对JavaScript运行机制的理解多了一点
我一开始的代码
y := 0
sumArr := method(
Arr,
if(Arr at(0) type == "List", // 检查是否为二维数组
sumArrsub(Arr), Arr sum)
)
sumArrsub := method(
arr,
for(i, 0, arr size - 1, // 求和
y = y + arr at(i) sum)
)
a := list(list(1,2,3), list(4,5,1), list(1, 2, 4))
c := list(list(1,1,1), list(2,2,2))
sumArr(a)
sumArr(c)
sumArr(list(1,2,3))
看下输出:
问题显而易见,y的值未清零,所以每次求值会在原先的y值上累加。
而且,这家伙没有局部变量这一说,所以怎样在每次求值时将y归零呢?
冷门语言难怪没人用,文档等于什么都没说,没有社区
只能自己摸索
这时我想到了JavaScriot的原型,我可以在原型上设个槽y, 然后在用个对象继承
这样每次对象用的y都原型上的y(y = 0), 不过,还需注意,调用方法后Io会自动在对象里里新添一个槽y, 我们要把代码中的“y = ” 变为 “y :=” (花了好久在找到这个关键的错误),不然每次调用还是累加对象的y, 使得每次调用都新赋值y
代码如下:
Object y := 0
Arr := Object clone
Arr sumArr := method(
Arr,
if(Arr at(0) type == "List", // 检查是否为二维数组
sumArrsub(Arr), Arr sum)
)
Arr sumArrsub := method(
arr,
for(i, 0, arr size - 1, // 求和
y := y + arr at(i) sum)
)
a := list(list(1,2,3), list(4,5,1), list(1, 2, 4))
c := list(list(1,1,1), list(2,2,2))
Arr sumArr(a)
Arr sumArr(c)
Arr sumArr(list(1,2,3))
看下输出:
The End