上記の Java ジェネリックからの続きです
上記では、クラス class GenDemo8742468051c85b06f0a0af9e3e506b5c
を作成しています。ホルダー T のスコープは制限されていません。実際には Object と同等です class GenDemo8742468051c85b06f0a0af9e3e506b5c
,持有者T的范围没有限制, 实际相当于Object.
但是我们有时需要传入的参数类型为某接口或类的实现或子类,而不是没有限制的Ojbect
所以使用限制泛型。再次我们让T为借口Collection的实现:
import java.util.collection;public class GenDemo<T extends Collection> { private T t; public GenDemo(T t) { this.t = t; } public void setT(T t) { this.t = t; } public T getT(){ return T; } }
class GenDemo2a9303dff3eed1b561b75d0dce9e5a56
使用限制泛型, 决定了持有者T的类型只能是Collection的实现类,如果传入的是非Collection类,译时就会报错。
注意:2a9303dff3eed1b561b75d0dce9e5a56
使用了关键字extends, 但是extends 后面也可以使用接口,也可以使用类, 此处的extends 并不是继承,此处应该理解为T的类型是实现xx接口的实现类,或者继承xx类的子类。
这里的例子仅演示了泛型方法的类型限定,对于泛型类中类型参数的限制用完全一样的规则,只是加在类声明的头部,如:
public class Demo<T extends Comparable & Serializable> { // T类型就可以用Comparable声明的方法和Seriablizable所拥有的特性了}
主要使用extends关键字, 此处的extends统一了原有的extends和implements的概念, 即实现接口和继承类都使用extends,但是,仍然遵循应用的体系,java只能继承一个类, 可以实现多个接口。也就是:
<T extends SomeClass & interface1 & interface2 & interface3>
接上文java泛型
在上文中我们使类class GenDemo8742468051c85b06f0a0af9e3e506b5c
,持有者T的范围没有限制, 实际相当于Object.
但是我们有时需要传入的参数类型为某接口或类的实现或子类,而不是没有限制的Ojbect
所以使用限制泛型。再次我们让T为借口Collection的实现:
import java.util.collection;public class GenDemo<T extends Collection> { private T t; public GenDemo(T t) { this.t = t; } public void setT(T t) { this.t = t; } public T getT(){ return T; } }
class GenDemo2a9303dff3eed1b561b75d0dce9e5a56
使用限制泛型, 决定了持有者T的类型只能是Collection的实现类,如果传入的是非Collection类,译时就会报错。
注意:2a9303dff3eed1b561b75d0dce9e5a56
ただし、場合によっては、制限のない Object ではなく、特定のインターフェイスまたはクラスの実装またはサブクラスであるパラメーターの型を渡す必要があるため、制限付きのジェネリックスを使用します。もう一度、T を Collection の実装の言い訳にします: public class Demo<T extends Comparable & Serializable> {
// T类型就可以用Comparable声明的方法和Seriablizable所拥有的特性了}
class GenDemo2a9303dff3eed1b561b75d0dce9e5a56
は制限されたジェネリックスを使用しており、これにより、ホルダー T の型が実装のみになり得ることが決定されます。 Collection のクラス。渡された場合、入力が Collection クラス以外の場合、変換中にエラーが報告されます。
2a9303dff3eed1b561b75d0dce9e5a56
ではキーワード ここでの例は、ジェネリック メソッドの型制限を示しているだけです。同じルールがジェネリック クラスの型パラメーターの制限にも使用されますが、それらは次のようにクラス宣言の先頭に追加されるだけです。複数のインターフェースの制限 ここでの extends は、extends とimplements の元の概念を統合します。つまり、実装インターフェースと継承されたクラスの両方が extends を使用します が、依然として Java のシステムに従います。 1 つのクラスのみを継承します
複数のインターフェースを実装できます。つまり、<T extends SomeClass & interface1 & interface2 & interface3>
上記の続き java ジェネリックス
1. 制限付きジェネリックス
class GenDemo8742468051c85b06f0a0af9e3e506b5c
を作成し、ホルダーはありません実際には Object と同等の T のスコープに制限します 🎜 ただし、無制限の Ojbect ではなく、特定のインターフェイスまたはクラスの実装またはサブクラスであるパラメーター型を渡す必要がある場合もあります 🎜 そのため、制限されたジェネリックスを使用します。もう一度、T を Collection の実装の言い訳として機能させます: 🎜rrreee🎜 class GenDemo2a9303dff3eed1b561b75d0dce9e5a56
は、制限されたジェネリックスを使用します。これにより、ホルダー T の型は、 Collection の実装クラス。渡された場合、入力が Collection クラス以外の場合、変換中にエラーが報告されます🎜。 🎜🎜注: 2a9303dff3eed1b561b75d0dce9e5a56
ではキーワード 🎜extends🎜 を使用しますが、インターフェイスは extends の後に使用することもできます。ここでの extends は継承ではありません。T の型は xx インターフェイスを実装する実装クラス、または xx クラスを継承するサブクラスであることを理解してください。 🎜 🎜ここでの例は、ジェネリック メソッドの型制限を示しているだけです。同じルールがジェネリック クラスの型パラメーターの制限にも使用されますが、それらは次のようにクラス宣言の先頭に追加されるだけです。複数のインターフェースの制限 🎜 🎜 ここでの extends は、extends とimplements の元の概念を統合します。つまり、実装インターフェースと継承されたクラスの両方が extends を使用します 🎜 が、依然として Java のシステムに従います。 1 つのクラスのみを継承します 🎜 複数のインターフェースを実装できます。つまり: 🎜rrreee🎜 3. ワイルドカード ジェネリック 🎜🎜 上記は、Java のジェネリックの詳細な内容です。さらに関連する内容については、PHP 中国語 Web サイト (www.php.cn) に注目してください。 🎜🎜🎜🎜🎜