0

私はグルーヴィーな初心者です。たぶんこれは簡単なことですが、配列/リストの + 演算子をオーバーロードして、このようにコーディングしたいと思います

def a= [1,1,1]
def b= [2,2,2]

assert [3,3,3] == a + b 
4

1 に答える 1

7

確立された動作をグローバルにオーバーライドすることはお勧めしません。しかし、あなたが主張するなら、これはあなたが尋ねるようにします:

ArrayList.metaClass.plus << {Collection b -> 
    [delegate, b].transpose().collect{x, y -> x+y}
}

よりローカライズされた代替手段は、カテゴリを使用することです。

class PlusCategory{
    public static Collection plus(Collection a, Collection b){
        [a, b].transpose().collect{x, y -> x+y}
    }
}
use (PlusCategory){
    assert [3, 3, 3] == [1, 1, 1] + [2, 2, 2]
}

ただし、おそらく汎用の zipWith メソッドを作成して (関数型プログラミングのように)、さまざまな動作を簡単に指定できるようにします...

Collection.metaClass.zipWith = {Collection b, Closure c -> 
    [delegate, b].transpose().collect(c)
}
assert [3, 3, 3] == [1, 1, 1].zipWith([2, 2, 2]){a, b -> a+b}
assert [2, 2, 2] == [1, 1, 1].zipWith([2, 2, 2]){a, b -> a*b}
于 2010-12-14T20:50:48.347 に答える