回答:
このような:
Set<T> mySet = new HashSet<>(Arrays.asList(someArray));
Java 9以降で、変更不可能なセットが問題ない場合:
Set<T> mySet = Set.of(someArray);
Java 10以降では、ジェネリック型パラメーターは配列コンポーネント型から推測できます。
var mySet = Set.of(someArray);
Arrays.asList
O(1)です。
Set<T> mySet = new HashSet<T>();
Collections.addAll(mySet, myArray);
それはCollections.addAll(java.util.Collection、T ...)です。、JDK 6です。
さらに、配列にプリミティブが満載されている場合はどうなりますか?
JDK <8の場合、私は明白な for
、ラップとセットへの追加を1つのパスで実行するループをます。
JDK> = 8の場合、魅力的なオプションは次のようなものです。
Arrays.stream(intArray).boxed().collect(Collectors.toSet());
java.util.Collections.addAll
。さらに、私はCommons Collectionsをもうお勧めしません。ジェネライズされておらず、Guavaが存在するためです。
addAll
O(n)になると思います。
グアバあなたが行うことができます。
T[] array = ...
Set<T> set = Sets.newHashSet(array);
new HashSet<T>(Arrays.asList(someArray))
。google.github.io/guava/releases/19.0/api/docs/com/google/common/…を
Java 8:
String[] strArray = {"eins", "zwei", "drei", "vier"};
Set<String> strSet = Arrays.stream(strArray).collect(Collectors.toSet());
System.out.println(strSet);
// [eins, vier, zwei, drei]
使用するオプションもありますStream
。さまざまな方法でストリームを取得できます。
Set<String> set = Stream.of("A", "B", "C", "D").collect(Collectors.toCollection(HashSet::new));
System.out.println(set);
String[] stringArray = {"A", "B", "C", "D"};
Set<String> strSet1 = Arrays.stream(stringArray).collect(Collectors.toSet());
System.out.println(strSet1);
// if you need HashSet then use below option.
Set<String> strSet2 = Arrays.stream(stringArray).collect(Collectors.toCollection(HashSet::new));
System.out.println(strSet2);
のソースコードCollectors.toSet()
は、要素が1つずつaに追加されていることを示していますがHashSet
、仕様ではそれがになることを保証していませんHashSet
。
「返されるSetのタイプ、変更可能性、直列化可能性、またはスレッドセーフ性は保証されません。」
したがって、後者のオプションを使用することをお勧めします。出力は次のとおりです。
[A, B, C, D]
[A, B, C, D]
[A, B, C, D]
Java 9ではSet.of
、提供された要素または配列の不変のセットを返す静的なファクトリメソッドが導入されました。
@SafeVarargs
static <E> Set<E> of(E... elements)
詳細については、不変セット静的ファクトリメソッドを確認してください。
また、次の2つの方法で不変セットを取得できます。
Set.copyOf(Arrays.asList(array))
Arrays.stream(array).collect(Collectors.toUnmodifiableList());
このメソッドCollectors.toUnmodifiableList()
はSet.of
、Java 9 で導入された方法を内部的に利用しています。詳細については、私の私の回答も確認してください。
Stream.of()
知りませんでした。についての小さな問題Collectors.toSet()
:仕様は要素を1つずつ追加することを保証しないと言いますが、それはそれが意味することです:「新しいものへの蓄積... Set
」。そして、それはもっと読みやすいです-具体的な型、可変性、直列化可能性、そしてスレッド安全性の保証が必要ないなら、私の心にはとても好ましいです。
HashSet
。それがaになることを保証するだけでありSet
、それが私が意味することです。私はそれを明確にしたいと思います。
あなたがした後、あなたはArrays.asList(array)
実行することができますSet set = new HashSet(list);
ここにサンプルのメソッドがあります、あなたは書くことができます:
public <T> Set<T> GetSetFromArray(T[] array) {
return new HashSet<T>(Arrays.asList(array));
}
ではEclipseのコレクション、次のように動作します:
Set<Integer> set1 = Sets.mutable.of(1, 2, 3, 4, 5);
Set<Integer> set2 = Sets.mutable.of(new Integer[]{1, 2, 3, 4, 5});
MutableSet<Integer> mutableSet = Sets.mutable.of(1, 2, 3, 4, 5);
ImmutableSet<Integer> immutableSet = Sets.immutable.of(1, 2, 3, 4, 5);
Set<Integer> unmodifiableSet = Sets.mutable.of(1, 2, 3, 4, 5).asUnmodifiable();
Set<Integer> synchronizedSet = Sets.mutable.of(1, 2, 3, 4, 5).asSynchronized();
ImmutableSet<Integer> immutableSet = Sets.mutable.of(1, 2, 3, 4, 5).toImmutable();
注:私はEclipseコレクションのコミッターです
すばやく:あなたは次のことができます:
// Fixed-size list
List list = Arrays.asList(array);
// Growable list
list = new LinkedList(Arrays.asList(array));
// Duplicate elements are discarded
Set set = new HashSet(Arrays.asList(array));
そして逆転する
// Create an array containing the elements in a list
Object[] objectArray = list.toArray();
MyClass[] array = (MyClass[])list.toArray(new MyClass[list.size()]);
// Create an array containing the elements in a set
objectArray = set.toArray();
array = (MyClass[])set.toArray(new MyClass[set.size()]);
私は上記のアドバイスから以下を書きました-それを盗んでください...それは素晴らしいです!
/**
* Handy conversion to set
*/
public class SetUtil {
/**
* Convert some items to a set
* @param items items
* @param <T> works on any type
* @return a hash set of the input items
*/
public static <T> Set<T> asSet(T ... items) {
return Stream.of(items).collect(Collectors.toSet());
}
}
時々、いくつかの標準ライブラリを使用することは大きな助けになります。Apache Commons Collectionを見てください。この場合、あなたの問題は単にこのようなものに変換されます
String[] keys = {"blah", "blahblah"}
Set<String> myEmptySet = new HashSet<String>();
CollectionUtils.addAll(pythonKeywordSet, keys);
java.util.Collections.addAll(myEmptySet, keys);
か?
使用CollectionUtils
またはArrayUtils
からstanford-postagger-3.0.jar
import static edu.stanford.nlp.util.ArrayUtils.asSet;
or
import static edu.stanford.nlp.util.CollectionUtils.asSet;
...
String [] array = {"1", "q"};
Set<String> trackIds = asSet(array);
ではJavaの10:
String[] strs = {"A", "B"};
Set<String> set = Set.copyOf(Arrays.asList(strs));
Set.copyOf
Set
指定されたの要素を含む変更不可能なものを返しますCollection
。
指定されたCollection
はであってはnull
ならず、null
要素を含んではいけません。
private Map<Integer, Set<Integer>> nobreaks = new HashMap();
nobreaks.put(1, new HashSet(Arrays.asList(new int[]{2, 4, 5})));
System.out.println("expected size is 3: " +nobreaks.get(1).size());
出力は
expected size is 3: 1
に変更
nobreaks.put(1, new HashSet(Arrays.asList( 2, 4, 5 )));
出力は
expected size is 3: 3
Android向けの解決策:
アスタリスク*
はspread
演算子です。コレクション内のすべての要素を個別に適用し、それぞれを順番にvararg
メソッドパラメータに渡します。これは次と同等です。
val myArray = arrayOf("data", "foo")
val mySet = setOf(*myArray)
// Equivalent to
val mySet = setOf("data", "foo")
// Multiple spreads ["data", "foo", "bar", "data", "foo"]
val mySet = setOf(*myArray, "bar", *myArray)
パラメータsetOf()
を渡さないと、空のセットになります。
に加えてsetOf
、特定のハッシュタイプに次のいずれかを使用することもできます。
hashSetOf()
linkedSetOf()
mutableSetOf()
sortableSetOf()
これは、コレクション項目タイプを明示的に定義する方法です。
setOf<String>()
hashSetOf<MyClass>()
new HashSet<Object>(Arrays.asList(Object[] a));
しかし、これはより効率的だと思います:
final Set s = new HashSet<Object>();
for (Object o : a) { s.add(o); }
HashSet
たとえば配列のサイズに基づいて設定されます。
Set<T> b = new HashSet<>(Arrays.asList(requiredArray));