首页
学习
活动
专区
圈层
工具
发布

创建子类对象时,父类构造函数中调用被子类重写的方法为什么调用的是子类的方法?

public static void main(String[] args) { A a = new A(); B b = new B(); } } 问题:为什么创建...A对象的时候父类会调用子类方法?...如果,子类重写了父类的方法,子类的方法引用会指向子类的方法,否则子类的方法引用会指向父类的方法引用。 如果子类重载了父类方法,则子类重载方法引用还指向子类方法。...如果子类方法没有重写也没有重载父类方法,则方法引用会指向父类方法。 当子类对象创建时,会先行调用父类的构造方法(构造方法也是方法),虚拟机会在子类方法区寻找该方法并运行。...其结果是当编译的时候,父类构造方法调用的方法的参数已经强制转换为符合父类方法的参数了。 上边代码在编译前已经转换为下面这个样子的了。

9.5K10

【Flutter】自定义 Flutter 组件 ( 创建自定义 StatelessWidget、StatefulWidget 组件 | 调用自定义组件 )

文章目 一、Flutter 组件简介 二、Flutter 自定义 StatelessWidget 组件流程 1、导入父类包 2、选择继承的父类 3、设置成员变量及构造函数 4、重写 build 方法...age; /// Dart 构造函数中 , {} 内的是可选参数 , 可选参数必须在参数的最后 /// 这里注意 , 可选参数如果定义为非空类型 , 那么必须有一个默认值 ///...age; /// Dart 构造函数中 , {} 内的是可选参数 , 可选参数必须在参数的最后 /// 这里注意 , 可选参数如果定义为非空类型 , 那么必须有一个默认值 ///...> createState() 方法返回值类型 State 需要设置一个泛型 , 说明该 State 是用于哪个 StatefulWidget 组件的 ; 该泛型必须是 StatefulWidget 的子类...age; /// Dart 构造函数中 , {} 内的是可选参数 , 可选参数必须在参数的最后 /// 这里注意 , 可选参数如果定义为非空类型 , 那么必须有一个默认值 ///

2.6K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    关于Java构造函数(Constructor)的常见问题总结1 为什么调用子类的构造方法的时候,默认会调用父类的构造方法2 常见错误:Implicit super constructor is und

    1 为什么调用子类的构造方法的时候,默认会调用父类的构造方法 看下面这个简单的例子: package cc; public class Sub extends Super { public Sub...** 之所以要调用父类的构造方法,是因为super类可能需要构造函数来初始化一些私有的成员变量。...解决这个问题很简单,我们可以给父类插入一个无参的构造函数,或者在子类构造函数中显示的调用的父类有参构造函数。 在子类的构造函数中显示的调用父类的构造函数 下面的代码是正确的。 ?...为什么Java在一个类已经实现了一个带参的构造函数的时候,不实现默认的无参构造函数? 这是个很有趣的问题。...我们知道如果在一个类中没有声明一个构造函数,那么编译器会隐式的帮我们实现一个无参的构造函数,但如果我们一旦一个构造函数,不管带不带参数,那么编译器都不会提供默认的构造函数,所以这么做的原因是为什么呢?

    3.9K41

    Stateful 组件的生命周期​

    组件时,首先执行其构造函数(上面的代码没有显示的构造函数,但有默认的无参构造函数),然后执行 createState 函数。...但构造函数并不是生命周期的一部分。...当 StatefulWidget 组件插入到组件树中时 createState 函数由 Framework 调用,此函数在树中给定的位置为此组件创建 State,如果在组件树的不同位置都插入了此组件,即创建了多个此组件...生命周期二:initState initState 函数在组件被插入树中时被 Framework 调用(在 createState 之后),此函数只会被调用一次,子类通常会重写此方法,在其中进行初始化操作...build,需要重写此方法的场景是:依赖发生变化时需要做一些耗时任务,比如网络请求数据。

    1.3K10

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

    /// 将泛型约束为某个类型的子类 class Member{ T _person; /// 构造函数中设置 T _person 成员的值 Member...int _grade; String school; String city; String address; /// 父类构造函数调用 : 如果父类有非空参数的构造函数, 子类必须实现相同参数的构造函数...} 是可选参数, 可选参数必须在构造函数参数列表中最后一个 /// /// 默认参数 : 可选参数中如果用户不初始化该可选参数 , 那么为其指定一个默认值 /// {this.city =...: 如果父类没有默认构造方法 (无参构造方法) , /// 必须在初始化列表中调用父类构造函数 , super(name, age) ; /// /// 构造方法方法体...// 定义格式 : 类名.方法名() // 父类构造函数 : 如果父类没有默认构造函数, 子类必须调用父类的构造函数 Student.cover(Student student):super

    8.2K00

    Flutter的生命周期

    组件时,首先执行其「构造函数」(上面的代码没有显示的构造函数,但有默认的无参构造函数),然后执行 「createState」 函数。...但构造函数并不是生命周期的一部分。...当 StatefulWidget 组件插入到组件树中时 「createState」 函数由 「Framework」 调用,此函数在树中给定的位置为此组件创建 「State」,如果在组件树的不同位置都插入了此组件...生命周期二:initState 「initState」 函数在组件被插入树中时被 Framework 调用(在 「createState」 之后),此函数只会被调用一次,子类通常会重写此方法,在其中进行初始化操作...「build」,需要重写此方法的场景是:依赖发生变化时需要做一些耗时任务,比如网络请求数据。

    2.1K30

    flutter 起步

    图片注意点:官网下载flutter包完成将安装包zip解压到你想安装Flutter SDK的路径(如:C:\src\flutter;注意,不要将flutter安装到需要一些高权限的路径如C:\Program...继承(extends)Flutter中的继承和Java中的继承是一样的:Flutter中的继承是单继承构造函数不能继承子类重写超类的方法,要用@override子类调用超类的方法,要用superFlutter...中的继承也有和Java不一样的地方:Flutter中的子类可以访问父类中的所有变量和方法,因为Flutter中没有公有、私有的区别上下文对象是整个APP Widget树结构中的Widget话柄,每个Wideget...1、在flutter里面,一切皆组件,在组件里面撑起flutter半边天的一个是无状态StatelessWidget组件,一个是有状态的StatefulWidget组件2、常用组件container:容器组件...控件类型从StatelessWidget到StatefulWidget的转换,因为Flutter在执行热刷新时会保留程序原来的state,而某个控件从stageless→stateful后会导致Flutter

    6.4K20

    Flutter Widget框架之旅 顶

    在编写应用程序时,通常会根据您的部件是否管理任何状态来创建新的部件,这些部件是StatelessWidget或StatefulWidget的子类。...它将它在构造函数中接收到的值存储在final的成员变量中,然后在build函数中使用它。例如,inCart布尔值可以在两个可视外观之间切换:一个使用当前主题的主要颜色,另一个使用灰色。...通过以这种方式管理状态,您不需要编写用于创建和更新子部件的单独代码。 相反,您只需实现可以处理这两种情况的构建函数。...State的一个子类可以覆盖initState来完成只需要发生一次的工作。 例如,您可以覆盖initState来配置动画或订阅平台服务。 ...initState的实现需要通过调用super.initState来启动。 当一个状态对象不再需要时,框架在状态对象上调用dispose。 您可以覆盖dispose函数来执行清理工作。

    7.9K20

    Widget的生命周期和渲染原理

    StatelessWidget的生命周期 1,初始化构造方法 2,widget的build函数 StatefulWidget的生命周期 1,statefulWidget的构造函数 2,createState...3,对应State的构造函数 4,对应State的初始化函数initState 5,didChangeDependencies 详见《使用InheritedWidget来进行状态管理》 6,state...我们知道,在需要修改数据更新UI的时候,只要调用setState然后在其中更改数据,这样UI就可以随之改变了,这是因为setState函数可以触发widget的销毁重建,也就是会触发state的build...接下来总结一下StatefulWidget的渲染流程: 创建完一个StatefulWidget之后,Flutter Frame会调用StatefulWidget的createElement()函数,在该函数中会创建一个...由于RenderObjectWidget是一个抽象接口类,所以createElement()函数需要在其子类中实现,我们这里以它的一个子类进行演示: 可以看到,在通过createElement创建Element

    1.7K20

    深入理解Flutter鸿蒙next版本 中的Widget继承:使用extends获取数据与父类约束

    本文将详细探讨如何在Flutter中使用extends来继承其他Widget,并在子类中访问父类的build方法以获取数据和约束规范。什么是Widget继承?...在Flutter中,继承是对象导向编程中的一个重要概念,它允许我们创建一个新的类,该类是一个现有类的子类。通过继承,我们可以重用代码,扩展现有类的功能,并定制其行为。...当我们定义一个新的Widget类时,通常会继承自Flutter框架中现有的Widget类,比如StatelessWidget或StatefulWidget。...这样,我们就可以利用父类的功能,并在此基础上进行扩展。基本概念StatelessWidget与StatefulWidgetStatelessWidget:表示一个不需要维护状态的Widget。...它通过构造函数接收计数值,并在build方法中调用CustomText来显示该值。写在最后通过继承Widget,我们可以轻松创建自定义的Flutter组件,并在子类中访问父类的属性和方法。

    76600

    Flutter--Flutter中Widget、App的生命周期

    在 Flutter 中一切皆 组件,而组件又分为 StatefulWidget(有状态) 和 StatelessWidget(无状态)组件 ,他们之间的区别是 StatelessWidget 组件发生变化时必须重新创建新的实例...组件时,首先执行其构造函数(上面的代码没有显示的构造函数,但有默认的无参构造函数),然后执行 createState 函数。...但构造函数并不是生命周期的一部分。...1.2.2 生命周期二:initState initState 函数在组件被插入树中时被 Framework 调用(在 createState 之后),此函数只会被调用一次,子类通常会重写此方法,在其中进行初始化操作...2.1 App的生命周期监听实现 App的生命周期的监听,在Flutter中需要通过监听器WidgetsBindingObserver监听器中的AppLifecycleState方法来是实现。

    4.9K31

    【Flutter】Dart 面向对象 ( 类定义 | 类的继承 | 私有变量 | 可选参数 | 默认参数 | 初始化列表 )

    ---- 使用 extends 关键字定义子类 , 注意如果父类有非空参数的构造函数, 子类必须实现相同参数的构造函数 ; // 继承 class Student extends Person{ Student...// 如果父类有非空参数的构造函数, 子类必须实现相同参数的构造函数 // 如果该类有父类 , 那么先调用父类的构造方法 , 完成父类的初始化 // 然后才能完成自己的初始化 // this.school...指定自有参数 // {this.school} 是可选参数, 可选参数必须在构造函数参数列表中最后一个 // 默认参数 : 可选参数中如果用户不初始化该可选参数 , 那么为其指定一个默认值.../ 父类构造方法 : 如果父类没有默认构造方法 (无参构造方法) , // 必须在初始化列表中调用父类构造函数 , super(name, age) ; // 构造方法方法体...; String address; // 如果父类有非空参数的构造函数, 子类必须实现相同参数的构造函数 // 如果该类有父类 , 那么先调用父类的构造方法 , 完成父类的初始化 //

    2.9K00

    Flutter简单介绍以及 Hello World解析

    它将其在构造函​​数中接收到的值存储在final成员变量中,然后在build函数中使用它们。 例如,inCart布尔值表示在两种视觉展示效果之间切换:一个使用当前主题的主色,另一个使用灰色。...如果希望在widget属性更改时收到通知,则可以覆盖didUpdateWidget函数,以便将旧的oldWidget与当前widget进行比较。...通过以这种方式管理状态,您不需要编写用于创建和更新子widget的单独代码。相反,您只需实现可以处理这两种情况的build函数。...子类化State可以重写initState,以完成仅需要执行一次的工作。 例如,您可以重写initState以配置动画或订阅platform services。...initState的实现中需要调用super.initState。 当一个状态对象不再需要时,框架调用状态对象的dispose。 您可以覆盖该dispose方法来执行清理工作。

    62610

    带你快速掌握Flutter的视图(Widgets)

    如果你查看Text Widget的实现,你会发现它是一个StatelessWidget的子类: new Text( 'I like Flutter!'...正如你所看到的,Text 没有与之关联的状态信息,它呈现了构造函数中传递的内容,仅此而已。...在Flutter中,因为Widget是不可变的,所以没有类似的方法。相反,我们可以传入一个函数或表达式,该函数或表达式返回一个Widget给父项,并通过布尔值控制该Widget的创建。...在这个场景中,controller 是动画过程的“主人”,而 CurvedAnimation 计算曲线,并替代 controller 默认的线性模式。...在Android中,可以通过继承View或已经存在的某个控件,然后覆盖其绘制方法来实现自定义View; 在iOS中,可以通过编写 UIView 的子类,或使用已经存在的 view 来重载并实现方法,以达到特定的功能

    12.8K10

    【Flutter】StatefulWidget 组件 ( 创建 StatefulWidget 组件 | MaterialApp 组件 | Scaffold 组件 )

    , 类似于 Android 的 ViewPager ; 二、创建 StatefulWidget 组件 ---- 创建空的 dart 文件 StatelessWidgetPage.dart , 导入最基础的材料设计包..., StatefulWidgetPage 名称 , 然后点击回车 , 就可以生成一个新的 StatefulWidget 组件 ; 新生成的代码如下 : import 'package:flutter/...的子类 ; 通过 MaterialApp 组件很容易实现符合 Material Design 规范的应用 ; MaterialApp 组件中的 tittle 字段就是标题设置 , theme 字段设置的是主题..., home 字段设置的是界面的主要子组件 ; 在上述示例中 下面的代码是 MaterialApp 构造函数源码 , 其中构造函数的可选参数就是可设置的选项 : class MaterialApp extends...floatingActionButton ; 底部导航栏设置 : bottomNavigationBar ; 侧边栏设置 : drawer ; Scaffold 组件构造函数源码 : 构造函数中的可选参数就是组件的可设置选项

    3K01

    【Flutter】Flutter 页面生命周期 ( 初始化期 | createState | initState | 更新期 | build | 销毁期 | dispose)

    文章目录 一、Flutter 页面生命周期 1、StatelessWidget 组件生命周期函数 2、StatefulWidget 组件生命周期函数 二、StatefulWidget 组件生命周期...createState 函数 : 所处时期 : 初始化期的生命周期函数 调用时机 : 创建 StatefulWidget 之后调用的第一个方法 ; 抽象方法 : 该方法是抽象方法 , 必须覆盖重写该方法...初始化期的生命周期函数 /// 创建 StatefulWidget 之后调用的第一个方法 , /// 该方法是抽象方法 , 必须覆盖 @override _WidgetLiftCyclePageState...初始化期的生命周期函数 /// 该方法是创建 Widget 组件时除构造方法之外的第一个方法 /// 该方法对应 Android 中的 onCreate 方法 /// 对应 iOS 中的 viewDidLoad...初始化期的生命周期函数 /// 创建 StatefulWidget 之后调用的第一个方法 , /// 该方法是抽象方法 , 必须覆盖 @override _WidgetLiftCyclePageState

    5.6K00

    Widget中的state到底是什么

    StatefulWidget的场景已经完全覆盖了StatelessWidget,因此我们在构建界面时,往往会大量使用StatefulWidget来处理静态的视图展示需求,看起来似乎也没什么问题。...UI编程范式 要想理解StatelessWidget与StatefulWidget的使用场景,我们首先需要了解,在Flutter中,如何调整一个控件(Widget)的展示样式,即UI编程范式。...这里,我有一个简单的判断规则:父Widget是否能通过初始化参数完全控制其UI展示效果。如果能,那么我们就可以使用StatelessWidget来设计构造函数接口了。...接下来,我就以Image的部分源码为例,和你说明StatefulWidget的构建过程,来帮助你理解这个知识点。 和上面提到的Text一样,Image的构造函数会接收要被这个类使用的属性参数。...这里你可能会有疑问,如果我在一个默认不可变的场景下使用StatefulWidget,那么我肯定不会主动调用其setState方法啊,如果我不主动调用setState,那么不就不会影响StatefulWidget

    3.6K20
    领券