次のJavaコードは存在しますが、それをgroovyに変換しようとしています。これをそのままSystem.arraycopyでそのまま保持する必要がありますか、またはこのようにgroovyに配列を組み合わせるより良い方法があります?
byte[] combineArrays(foo, bar, start) {
def tmp = new byte[foo.length + bar.length]
System.arraycopy(foo, 0, tmp, 0, start)
System.arraycopy(bar, 0, tmp, start, bar.length)
System.arraycopy(foo, start, tmp, bar.length + start, foo.length - start)
tmp
}
ありがとうございました
def a = [1, 2, 3]
def b = [4, 5, 6]
assert a.plus(b) == [1, 2, 3, 4, 5, 6]
assert a + b == [1, 2, 3, 4, 5, 6]
配列を使用したい場合:
def abc = [1,2,3,4] as Integer[] //Array
def abcList = abc as List
def xyz = [5,6,7,8] as Integer[] //Array
def xyzList = xyz as List
def combined = (abcList << xyzList).flatten()
リストの使用:
def abc = [1,2,3,4]
def xyz = [5,6,7,8]
def combined = (abc << xyz).flatten()
def a = [1, 2, 3]
def b = [4, 5, 6]
a.addAll(b)
println a
>> [1, 2, 3, 4, 5, 6]
私は一緒に行きます
byte[] combineArrays(foo, bar, int start) {
[*foo[0..<start], *bar, *foo[start..<foo.size()]]
}
これは次のように行うことができます:
def newCombine(foo,bar,start) {
([].add + foo[0..<start]+bar+foo[start..<foo.size()]).flatten()
}
あらゆる種類の配列(byte [])またはリストで機能します
トリックは、ネストされた配列を1つに結合するflatten()メソッドです。
def a = [1, 2, 3]
def b = [4, 5, 6]
def combined = [a, b].flatten()
assert combined == [1, 2, 3, 4, 5, 6]
println(combined)
Null値を削除するには、次のようにfindAll()を使用できます。
def a = null
def b = [4, 5, 6]
def combined = [a, b].flatten().findAll{it}
assert combined == [4, 5, 6]
println(combined)
配列が未定義の場合、上記のすべてのソリューションは失敗します。
def a = [1,2]
def b
assert a+b == [1, 2, null]
これはおそらくあなたが望むものではありません。
追加する前に、配列が存在するかどうかをテストします。
def a = [1,2,3,4]
def b // null array
def c = [0,4,null,6]
def abc = []
[a,b,c].each{ if (it) abc += it }
assert abc == [1, 2, 3, 4, 0, 4, null, 6]
、またはすべてを追加してから出力をフィルタリングします。
(a+b+c).findAll{ it != null }
(ここでnull
は元の配列の有効な値ではないと仮定します。これは、Groovyに十分に見えない場合でも、最初のソリューションの方がはるかに優れていることを意味します。)