首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

具有自引用类型约束的泛型类

具有自引用类型约束的泛型类是一种在Java中使用泛型的方法,它允许泛型类型参数引用自身。这种约束可以用于实现树状结构、图状结构等数据结构,以及实现一些递归操作。

以下是一个简单的示例:

代码语言:java
复制
public class TreeNode<T extends TreeNode<T>> {
    private T parent;
    private List<T> children;

    public TreeNode() {
        children = new ArrayList<>();
    }

    public T getParent() {
        return parent;
    }

    public void setParent(T parent) {
        this.parent = parent;
    }

    public List<T> getChildren() {
        return children;
    }

    public void addChild(T child) {
        children.add(child);
        child.setParent(this);
    }
}

在这个示例中,TreeNode类具有一个泛型类型参数T,该参数继承自TreeNode<T>,这意味着T必须是TreeNode的子类。这样,我们就可以在TreeNode类中使用T作为parentchildren的类型,从而实现自引用。

这种自引用类型约束的泛型类在实际应用中可以用于实现各种树状结构,例如文件系统、组织结构、表达式树等。它还可以用于实现递归操作,例如递归遍历树状结构、递归计算斐波那契数列等。

在使用自引用类型约束的泛型类时,需要注意避免堆栈溢出等问题。例如,在递归遍历树状结构时,需要注意避免遍历过深导致堆栈溢出。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

【Flutter】Dart ( | 方法 | 特定类型约束 )

文章目录 一、Dart 方法 二、Dart 特定类型约束 三、Dart 自带 四、完整代码示例 五、 相关资源 一、Dart 方法 ---- 作用 : 为 ,...接口 , 方法 提供复用性 , 支持类型不确定数据类型 ; : 提高代码复用程度 ; 方法 : 参数或返回值有类型约束 , 参数或返回值类型必须符合对应类型 , 使用时会进行类型检查约束..., 类型设置为 int 类型 Cache cache2 = Cache(); // 调用方法时 , 传入参数必须符合对应类型 // 约束 : 使用时会进行类型检查约束...Tom I/flutter (24673): 测试, 类型整型, 获取缓存内容为 18 二、Dart 特定类型约束 ---- 还可以进行特定类型约束 , 如指定该类型必须是某个子类..., 使用 约束必须是某个子类 ; 示例代码 : /// 特定类型约束 /// 将约束为某个类型子类 class Member<T extends

4.8K00

【Kotlin】 ① ( | 参数 | 型函数 | 多参数 | 类型约束 )

文章目录 一、 二、参数 三、型函数 四、多参数 五、类型约束 一、 ---- 定义一个 , 将 参数 T 放在 尖括号 中 , 该参数放在 名后...下面的代码中 , 声明了 Student , 该 接收 T 类型参数 , 在主构造函数中接收 T 类型参数 , 在该中声明了 T 类型成员属性 ; class Student...R 类型是 Boolean 类型 ; 3.14 true 五、类型约束 ---- 在 , 型函数 中 , 使用前 , 需要声明 参数 : 参数 声明 : 如果类中...return action(item) } 在 尖括号 中声明 参数 时 , 可以指定 类型 约束 , 如 类型 必须是某个类型子类 ; 在下面的代码中 , Soldier... 进行了约束 , 必须是 Weapon 子类类型 ; class Soldier(_item: T) {} Weapon 是父 , 其有一个 子类 AK47

2.7K10

Kotlin 类型参数约束

上一篇文章讲了 Kotlin :基本使用,接下来我们再进一步了解使用相关进阶知识。本篇是 Kotlin 类型参数约束讲解,更多内容可点击链接查看。...Kotlin :基本使用Kotlin 类型参数约束系列持续更新中,欢迎关注订阅。...为什么需要类型参数约束在上一篇文章里,我们使用定义了一个列表List,使用这个列表,我们可以在使用时候,实例化出各种具体类型列表,比如字符串列表List、整型列表List...我们使用来实现打印机Printer,显然这个类型参数需要满足两个条件:T必须实现Printable接口T必须实现Serializable接口这两个条件无法用前一节简单类型参数约束来表达,因此...中属性也同样变得可空,这使得在具体实现时候,需要考虑参数为空情况,也让编写代码具体实现变得复杂。

2.1K31

C#入门集合、方法、约束委托

不然 集合和ArrayList装箱拆箱 常见类型 方法 约束 委托 ###很难理解?...将类型参数化以达到代码复用提高软件开发工作效率一种数据类型引用类型,是堆对象,主要是引入了类型参数这个概念。...当针对不同类型具有相同行为时候,也就是发挥作用时候。 优点: 1.使用、方法,我们可以极大提高代码重用性,不需要对类型不同代码相同(仅类型参数不同)代码写多次。...where T : class 类型参数必须是引用类型;这一点也适用于任何、接口、委托或数组类型。 where T:new() 类型参数必须具有无参数公共构造函数。...当与其他约束一起使用时,new() 约束必须最后指定。 where T: 类型参数必须是指定或派生指定

2.5K30

【Kotlin】总结 ★ ( | 参数 | 型函数 | 多参数 | 类型约束 | 可变参数结合 | out 协变 | in 逆变 | reified 检查参数类型 )

文章目录 一、 二、参数 三、型函数 四、多参数 五、类型约束 六、可变参数 vararg 关键字与结合使用 七、使用 [] 运算符获取指定可变参数对象 八、 out 协变...都使用 T 来表示 ; 代码示例 : 下面的代码中 , 声明了 Student , 该 接收 T 类型参数 , 在主构造函数中接收 T 类型参数 , 在该中声明了 T...R 类型是 Boolean 类型 ; 3.14 true 五、类型约束 ---- 在 , 型函数 中 , 使用前 , 需要声明 参数 : 参数 声明 : 如果类中...return action(item) } 在 尖括号 中声明 参数 时 , 可以指定 类型 约束 , 如 类型 必须是某个类型子类 ; 在下面的代码中 , Soldier... 进行了约束 , 必须是 Weapon 子类类型 ; class Soldier(_item: T) {} Weapon 是父 , 其有一个 子类 AK47

3.7K10

方法、类型通配符使用

方法、类型通配符使用 一.        声明和非声明类似,除了在名后面添加了类型参数声明部分...和方法一样,类型参数声明部分也包含一个或多个类型参数,参数间用逗号隔开。一个参数,也被称为一个类型变量,是用于指定一个类型名称标识符。...下面是定义方法规则: 所有方法声明都有一个类型参数声明部分(由尖括号分隔),该类型参数声明部分在方法返回类型之前(在下面例子中)。...类型参数能被用来声明返回值类型,并且能作为方法得到实际参数类型占位符。 方法体声明和其他方法一样。...注意类型参数只能代表引用类型,不能是原始类型(像int,double,char等) 1 public class GenericMethodTest 2 { 3 // 方法 printArray

3.8K40

TypeScript中型函数、接口,约束,一文读懂

在使用过程中,操作数据类型会根据传入类型实参来确定 可以用在 、接口、方法中,分别被称为 接口、方法。...方法同时具备 通用性、类型安全和性能 ,是非和非方法无法具备 优势:高性能变成方式、达到代码复用、提高代码通用性、 使用类型参数(变量),它是一种特殊变量,代表类型而不是值...,参数n:类型):返回类型 { //函数体 } 定义 class 名{ //属性和方法签名} class 类型{ //属性和方法签名 } 接口定义...T 必须放在中间 一般不能单独出现,会出现在 函数、 接口 、中 ,在函数体内,编译器不知道变量T具体数据类型,只能认为其为 任意值(any) 类型 约束 参数T类似于any类型...但是有些情况下,函数需要处理数据有一定约束,比如有一个型函数需要访问参数Tlength属性,并加1。基于这种需求,必须对参数T进行约束,也就是约束

2K30

C#中类型参数约束

因为我们数组中存储元素类型是不确定,所以这里我们用到了,其中where T : strut子句约束参数类型T必须为值类型。当然这个程序我们不使用,直接定义Object类型数组也可以。...下面重点说说C#中类型参数约束: 在定义时,可以对客户端代码能够在实例化时用于类型参数类型种类施加限制。 如果客户端代码尝试使用某个约束所不允许类型来实例化,则会产生编译时错误。...有关更多信息,请参见使用可以为 null 类型(C# 编程指南)。 T:class 类型参数必须是引用类型;这一点也适用于任何、接口、委托或数组类型。...T:new() 类型参数必须具有无参数公共构造函数。 当与其他约束一起使用时,new() 约束必须最后指定。 T: 类型参数必须是指定或派生指定。...于是,我想能不能写一个简单,其中里面实现对数值类型加减乘除四则运算,遇到问题是 :where子句后面的约束怎么写,我查看数值Int32等等,它们是Object,如果直接定义一个参数

3.6K60

【Java 简介 ( | 方法 | 静态方法 | 方法完整示例 )

文章目录 一、简介 二、 三、方法 四、静态方法 五、方法完整示例 一、简介 ---- 可以 简单理解为 参数化类型 , 主要作用在 , 方法 , 接口 上... 也可以有参数 , 将 类型 作为 参数 传入中 ; 接口 : 接口 参数 , 也可以是 ; 将 类型 传入 方法 , , 接口 中 , 可以 动态地 指定一些类型 ;...性能 ; 二、 ---- : 在 名后面 使用 声明 , 则在该类中 , 可以使用该类型 T 类型 ; 特别注意 , 该类中 如下 2 个方法 不是 方法...; 其中 参数 , 返回值 类型是 T , 但 这个 T 是作为一个正常类型使用 , 并不是声明在 方法 中 ; 如果 , 接口 , 方法 是 , 接口 , 方法 , 则该...; 方法 与 : 不同 : 方法指定 T 与 T 没有任何关系 , 这两个 T 可以是不同类型 ; 相同 : 方法中定义 T

13.5K30

TypeScript-在约束中使用类型参数

约束中使用类型参数概述一个被另一个约束, 就叫做 约束中使用类型参数博主需求: 定义一个函数用于根据指定 key 获取对象 value:let getProps = (obj: object..., key: string): any => { return obj[key];}如上代码在编译器当中是会报错,报错原因就是它不知道 obj[key] 返回到底是不是 any 这个类型,...a 和 b 都是存在 key,如果这个时候我要获取一个 c key value 那么就直接是 undefined 了,说明一个问题,代码不够健壮, 明明 obj 中没有 c 这个 key 但是却没有报错...,那么这时就可以利用 在约束中使用类型参数 来解决该问题,代码如下:图片let getProps = (obj: T, key: K): any => {...,我一般看到都会回复

17110

C#高级语法之约束类型安全、逆变和协变(思想原理)

其实就是一个不确定类型,可以用在和方法上,在声明期间没有明确定义类型,编译完成之后会生成一个占位符,只有在调用者调用时,传入指定类型,才会用确切类型将占位符替换掉。...比如我们需要调用动物CanRun方法,让动物跑一下再放入集合里(z),因为我们知道动物都是继承Animal,所有动物都会有CanRun方法,但是如果传入过来一个飞Desk我们还能使用CanRun...二、约束 约束就是对(传入类型)进行约束约束就是指定该类型必须满足某些特定特征,例如:可以被实例化、比如实现Animal等等 我们来看一下官方文档上都有那些约束: 说明 对多个参数应用约束...where : 约束1、约束2.......然后我们来为AnimalHouse添加约束为:必须包含公共无参构造函数和基必须是Animal //Animal约束T必须是Animal子类或者本身,new()约束放在最后 public class

6.7K30

擦除是什么意思_方法区别

大家好,又见面了,我是你们朋友全栈君 在严格代码里,带声明总应该带着类型参数。但为了与老Java代码保持一致,也允许在使用带声明时不指定实际类型。...如果没有为这个指定实际类型,此时被称作raw type(原始类型),默认是声明该形参时指定第一个上限类型。...当把一个具有信息对象赋给另一个没有信息变量时,所有在尖括号之间类型信息都将被扔掉。...比如一个 List 类型被转换为List,则该List对集合元素类型检查变成了参数上限(即Object)。...对而言,可以直接把一个List对象赋给一个 List 对象,编译器仅仅提示“未经检查转换”。

1.3K30

正确用法

在准备下次直播Java基础内容中,偶然看到Java这个知识点,突然有了点想法,之前一直纠结一个问题有了解答思路。...问题:我在多线程任务基中定义了一个T对象t,但是一直没有找到一个特别合适发光点,感觉跟重新写一个内部类差别不大,偶尔在匿名中使用,非但没有更加灵活,反而衍生出一些其他多线程锁问题。...,额外属性对象就可以用这个T代替。...突觉自己以前走了很多弯路,对掌握和应用太浅薄,说干就干了,马上对现有的性能测试框架中abstract和实现都改一遍。...,被继承中T可以声明成为HttpRequestBase,然后在代码中关于父操作,如super(request, times, mark);中是可以成立,然后在本类名后面的不能声明对象,

84740

相关时,如何在两个之间创建类似子类型关系呢

Integer(10)); // OK someMethod(new Double(10.1)); // OK 当然也是如此,在执行类型调用时,将Number作为其类型参数传递,如果参数是...那么问题来了,当相关时,如何在两个之间创建类似子类型关系呢?例如如何让Box 和Box变得与Box有关呢?...为了搞懂这个问题,我们先来了解一下同一类型对象是如何实现子类型吧。...小结:可以通过继承或者实现接口来对其进行子类型化。 搞懂了子类型问题,我们回到“如何在两个之间创建类似子类型关系“问题。...或者接口并不会仅仅因为它们类型之间有关系而变得相关,如果要达到相关,我们可以使用通配符来创建或接口之间关系。

2.8K20

Java详解:和Class使用。方法详细使用实例

这里可能看不懂,开篇总是困难,下面看看如果没有的话,我们要怎么做; 2、没有会怎样  先看下面这段代码: 我们实现两个能够设置点坐标的,分别设置Integer类型点坐标和Float类型点坐标...(2)中使用 这个T表示派生Object任何,比如String,Integer,Double等等。这里要注意是,T一定是派生于Object。...,普通构造函数是这样:Point p = new Point() ;  而构造则需要在名后添加上,即一对尖括号,中间写上要传入类型。...那我们稍微加深点难度,构造一个多个变量,并继承Info接口:    [java]     view plain     copy    class InfoImpl implements...,任何值都可以(但必须是派生Object类型,比如String,Integer等),函数会在内部根据传进去参数来识别当前T类别。

3.2K50
领券