C#/.NET のようなものはありますか
IEnumerable<int> range = Enumerable.Range(0, 100); //.NET
Javaで?
C#/.NET のようなものはありますか
IEnumerable<int> range = Enumerable.Range(0, 100); //.NET
Javaで?
編集済み:Java 8として、これは可能ですjava.util.stream.IntStream.range(int startInclusive, int endExclusive)
Javaにはそのようなものはありませんが、次のようなものを持つことができます:
import java.util.Iterator;
public class Range implements Iterable<Integer> {
private int min;
private int count;
public Range(int min, int count) {
this.min = min;
this.count = count;
}
public Iterator<Integer> iterator() {
return new Iterator<Integer>() {
private int cur = min;
private int count = Range.this.count;
public boolean hasNext() {
return count != 0;
}
public Integer next() {
count--;
return cur++; // first return the cur, then increase it.
}
public void remove() {
throw new UnsupportedOperationException();
}
};
}
}
たとえば、次の方法で Range を使用できます。
public class TestRange {
public static void main(String[] args) {
for (int i : new Range(1, 10)) {
System.out.println(i);
}
}
}
また、直接使用したくない場合はnew Range(1, 10)
、ファクトリ クラスを使用できます。
public final class RangeFactory {
public static Iterable<Integer> range(int a, int b) {
return new Range(a, b);
}
}
そして、ここに私たちの工場テストがあります:
public class TestRangeFactory {
public static void main(String[] args) {
for (int i : RangeFactory.range(1, 10)) {
System.out.println(i);
}
}
}
これらが役立つことを願っています:)
Javaには組み込みサポートはありませんが、自分で簡単に構築できます。概して、Java API は、この種の機能に必要なすべてのビットを提供しますが、それらをすぐに組み合わせることはできません。
Java は、物事を組み合わせる方法は無数にあるというアプローチをとっています。適切なビルディング ブロックのセットを使用すると、他のすべてを簡単に構築できます (これは Unix の哲学でもあります)。
他の言語 API (C# や Python など) はより慎重な見方をしており、実際に簡単にするためにいくつかのことを選んでいますが、それでも難解な組み合わせが可能です。
Java アプローチの問題の典型的な例は、 Java IOライブラリーに見られます。出力用のテキスト ファイルを作成する標準的な方法は次のとおりです。
BufferedWriter out = new BufferedWriter(new FileWriter("out.txt"));
Java IO ライブラリは、柔軟性のためには非常に良いアイデアであるDecorator パターンを使用しますが、多くの場合、バッファリングされたファイルが必要になることはありませんか? これを Python の同等のものと比較すると、典型的な使用例が非常に単純になります。
out = file("out.txt","w")
Arraylist をサブクラス化して、同じことを実現できます。
public class Enumerable extends ArrayList<Integer> {
public Enumerable(int min, int max) {
for (int i=min; i<=max; i++) {
add(i);
}
}
}
次に、反復子を使用して、最小から最大までの整数のシーケンスを取得します (両方を含む)
編集
sepp2k が述べたように、上記の解決策は迅速で、汚れていて実用的ですが、いくつかの重大な撤回があります (O(1) を持つ必要があるのに、空間に O(n) だけでなく)。C# クラスのより本格的なエミュレーションについては、Iterable とカスタム イテレータを実装するカスタム Enumerable クラスを作成したいと思います (ただし、ここではありません ;) )。