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

为什么在flutter中使用provider时不执行类的构造函数?

在Flutter中使用Provider时,不会执行类的构造函数,是因为Provider是基于InheritedWidget实现的。InheritedWidget是Flutter中一种特殊的Widget,它可以在Widget树中共享数据,并且当数据发生变化时,可以自动通知依赖该数据的子Widget进行更新。

Provider通过InheritedWidget的方式将数据共享给子Widget,而不是通过类的构造函数传递数据。这样做的好处是可以避免在Widget树中频繁地传递数据,提高了代码的可读性和可维护性。

当使用Provider时,通常会创建一个继承自ChangeNotifier的数据模型类,并在该类中定义需要共享的数据和对数据进行操作的方法。然后,在Widget树中使用Provider提供该数据模型类的实例,子Widget可以通过Provider.of<T>(context)获取该实例,并监听数据的变化。

当数据发生变化时,Provider会通知依赖该数据的子Widget进行更新,而不会重新执行类的构造函数。这是因为Provider会在InheritedWidget的updateShouldNotify方法中判断数据是否发生变化,只有当数据发生变化时,才会触发子Widget的更新。

总结一下,在Flutter中使用Provider时不执行类的构造函数的原因是:

  1. Provider是基于InheritedWidget实现的,通过共享数据的方式传递数据给子Widget,而不是通过构造函数传递。
  2. Provider通过判断数据是否发生变化来触发子Widget的更新,而不是重新执行类的构造函数。

推荐的腾讯云相关产品:腾讯云云开发(https://cloud.tencent.com/product/tcb)是一款无服务器云开发平台,提供了丰富的后端服务和开发工具,可以帮助开发者快速构建和部署云端应用。腾讯云云开发可以与Flutter中的Provider结合使用,实现数据的共享和更新。

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

相关·内容

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

A对象的时候父类会调用子类方法?...但是:创建B对象父类会调用父类的方法? 答案: 当子类被加载到内存方法区后,会继续加载父类到内存中。...如果,子类重写了父类的方法,子类的方法引用会指向子类的方法,否则子类的方法引用会指向父类的方法引用。 如果子类重载了父类方法,则子类重载方法引用还指向子类方法。...如果子类方法没有重写也没有重载父类方法,则方法引用会指向父类方法。 当子类对象创建时,会先行调用父类的构造方法(构造方法也是方法),虚拟机会在子类方法区寻找该方法并运行。...其结果是当编译的时候,父类构造方法调用的方法的参数已经强制转换为符合父类方法的参数了。 上边代码在编译前已经转换为下面这个样子的了。

6.2K10
  • 最全面的c++中类的构造函数高级使用方法及禁忌

    说明一下,我用的是gcc7.1.0编译器,标准库源代码也是这个版本的。 本篇文章讲解c++中,构造函数的高级用法以及特殊使用情况。 1....,我们执行一下程序,结果如下: call constructors throw something 可以看到没有执行析构函数,那如果构造函数在申请动态内存以后抛出异常,就会出现内存泄露的问题,那么为什么没有执行析构函数呢...,在存在动态内存的class里面使用移动构造就要小心了,一不小心就会出现问题哦,具体移动构造怎么实现可以参考上面第一点中的代码。...,那根据多态规则,父类的构造函数将不会被执行,这也是不成立的。...,那就很清晰了,在main函数执行以前,全局变量和静态变量的构造函数会先执行。

    1.8K30

    【Java 虚拟机原理】Java 类中的类加载初始化细节 ( 只使用类中的常量时加载类不会执行到 ‘初始化‘ 阶段 )

    , 解析 ) -> 初始化 这个完整的流程 ; 如 : 如果是 public final static 修饰的常量值 , 在编译阶段 , 就会将该值放到常量池中 ; 在类加载的过程中 , 只要执行到...加载 -> 连接 ( 验证 , 准备 , 解析 ) 阶段 , 就可以完成常量池的初始化 , 即使没有执行 初始化 这个步骤 , 也不影响使用类中的常量值 ; 在 连接 的 准备 阶段 , 为 普通 的...字节码文件 , 然后使用 javap -v -Student.class 查看该字节码文件的附加信息 ; 在 " 常量表 " 中 , 发现了常量值 18 , 这个常量值是在编译阶段就编译到了字节码中...; 在 " 连接 " 的 " 准备 " 阶段 , 该常量值就设置完毕 ; 出于最大限度性能优化的考虑 , 如果不使用该类的其它值 , 就不会执行 " 初始化 " 阶段 ; 因此这里不会调用 静态代码块..., 只会为其在内存分配空间 ; 创建数组时 , 触发的是 Student[] 数组类型的 类加载初始化 , 但是不会触发 Student 类的初始化操作 ; 如果调用数组中的元素时 , 就需要初始化

    3.6K20

    React useEffect中使用事件监听在回调函数中state不更新的问题

    很多React开发者都遇到过useEffect中使用事件监听在回调函数中获取到旧的state值的问题,也都知道如何去解决。...// 再次点击addEventListenerShowCount的按钮 eventListener事件回调函数打印state值控制台打印结果如下图片手动实现的简易useEffect中,事件监听回调函数中也会有获取不到...对象类似于按钮btn refApp函数类似React App纯函数组件每次state变化,React 函数会重新执行,所以我们可以进行如下模拟操作图片这个示例的运行过程就比较好理解,第一次执行App函数...在React函数中也是一样的情况,某一个对象的监听事件的回调函数,这个对象相当于全局作用域变量(或者与函数同一层作用域链),在回调函数中获取到的state值,为第一次运行时的内存中的state值。...而组件函数内的普通函数,每次运行组件函数中,普通函数与state的作用域链为同一层,所以会拿到最新的state值。

    11K60

    Flutter 中文文档:简单的应用状态管理

    这里我们出现了第一个问题:我们把当前购物车的状态放在哪合适呢? 2. 提高状态的层级 在 Flutter 中,有必要将存储状态的对象置于 widget 树中对应 widget 的上层。 为什么呢?...但是这样的方式很难避免出现 bug。 在 Flutter 中,每次当 widget 内容发生改变的时候,你就需要构造一个新的。...然而当购物车在 widget 树中,处于 MyListItem 的层级之上时,又该如何访问状态呢? 一个简单的实现方法是提供一个回调函数,当 MyListItem 被点击的时候可以调用。...在相对复杂的应用中,由于会有多个模型,所以可能会有多个 ChangeNotifier。(不是必须得把 ChangeNotifier 和 provider 结合起来用,不过它确实是一个特别简单的类)。...ChangeNotifier 是 flutter:foundation 的一部分,而且不依赖 Flutter 中任何高级别类。测试起来非常简单(你都不需要使用 widget 测试)。

    2K10

    nextline函数_在JAVA中Scanner中的next()和nextLine()为什么不能一起使用?

    回车符 “\r” 它被丢弃在缓冲区中,现在缓冲区中,只有一个 \r ,于是 下一次 nextLine 扫描的时候就又扫描到了 \r,返回它之前的内容,也是啥都没有 “” ,然后再把 \r 去掉, 对于...,而我们在控制台中输入的数据也都是被先存入缓冲区中等待扫描器的扫描读取。...这个扫描器在扫描过程中判断停止的依据就是“结束符”,空格,回车,tab 都算做是结束符 而坑点在于 next 系列的,也就是下面这些函数:next nextInt nextDouble nextFloat...这些函数与 nextLine 连用都会有坑 坑点就是 next 系列的函数返回了数据后,会把回车符留在缓冲区,因此我们下一次使用 nextLine 的时候会碰到读取空字符串的情况 解决方案:输入都用...nextLine ,做格式转换 输入 next 系列函数调用后,中间调用一次 nextLine 调用去掉了回车符后,再调用一次 nextLine 调用真正输入我们的数据 都使用 nextLine: class

    2.7K10

    使用Provider来进行状态管理

    第二步,在lib目录下新增一个provider文件夹,然后在该文件夹内放我们的各个状态管理类。(本例中我们新建了一个Counter.dart) ?..._count++; //表示更新状态.它会重新触发所有监听了该Provider的类的build方法 //在本例中,当notifyListeners方法执行的时候,购物车页面与我的页面的build...上例中的状态管理类Counter中的状态值_count,初始化该值的时候,如果该初始值不需要计算,我们在声明_count的时候进行初始赋值即可,如下: class Counter with ChangeNotifier..._count++; notifyListeners();//表示更新状态 } } 但是如果该初始值需要计算得到,那么我们可以在Counter的构造函数中进行该计算。...因为我们需要在main.dart中配置全局监听的类(这里是Counter类),配置的时候需要实例化该类(Counter),也就是会触发Counter的构造函数。

    2.1K30

    记住,永远都不要在 Flutter 中使用全局变量

    以上所有原因都说明了为什么在 Flutter 中永远不应该使用全局变量。...全局变量导致“面条”代码 由于程序中的每个函数都可以修改全局变量,因此很难跟踪更改。如果你正在构建一个大型应用程序,在 Flutter 中使用全局变量的情况会升级。...但是,有些开发人员会使用全局变量,因为他们在一个小团队中,并且在某些情况下不利于更改。 但是,无论应用程序的大小如何,当需要维护代码时,全局变量都会带来挑战。...使用以下代码片段添加和使用 Provider 包插件: dependencies: flutter: sdk: flutter provider: ^3.1.0 Provider 程序包还允许你与多个类共享小部件状态...要在 Flutter 应用程序启动中开始使用 GetX,请将 get 添加到你的 pubspec.yaml 文件中: dependencies: get: 接下来,导入使用 GetX 库函数和组件时需要的

    3.6K30

    2021 年值得期待的 Flutter 数据流管理方案

    不像 Redux 在 React 中独占鳌头,Flutter 的数据流管理方案层出不穷,本文旨在介绍在2021年值得使用的 Flutter 数据流管理方案,除了大家都比较熟悉的 InheritedWidget...ViewModel 和 Model 层的界限,使得 ViewModel 不持有 Model 层,这样可以规避 VM 重建时 Model 层重建,结构如下所示: ?...封装中用到的几个类如下: ChangeNotifier:是 Flutter 实现的一个监听-订阅类 NormalPageState:页面状态枚举值 NormalPageController:负责页面状态变化...方法1:flutter_riverpod 提供了一个 ConsumerWidget,它会在 build 函数中多提供了一个 ScopedReader 函数来从 provider 中获取值并使 state...若非在 build 函数中,可以使用 context.read 获得 provider class IncrementNotifier extends ChangeNotifier { int _

    2K20

    【C++】构造函数分类 ② ( 在不同的内存中创建类的实例对象 | 栈内存中创建实例对象 | new 关键字创建对象 )

    一、在不同的内存中创建类的实例对象 1、栈内存中创建实例对象 在上一篇博客 【C++】构造函数分类 ① ( 构造函数分类简介 | 无参构造函数 | 有参构造函数 | 拷贝构造函数 | 代码示例 - 三种类型构造函数定义与调用..., 会自动将栈内存中的实例对象销毁 ; 栈内存中 调用 构造函数 创建的 实例对象 , 不需要关注其内存占用 ; 2、堆内存中创建实例对象 在 栈内存 中声明 类 的 实例对象 方式是 : 该 s1...; Student* s2; 在 C++ 语言中 , 可以使用 new 关键字 , 调用有参构造函数 , 创建类的 实例对象 ; 在下面的 C++ 代码中 , 声明并定义了 MyClass 类 , 该类定义了一个有参构造函数..., 接受两个整数作为 构造函数参数 ; 在 main 函数中 , 使用 使用 new 关键字 来调用 有参构造函数 创建 MyClass 类实例对象 ; class MyClass { public...实例对象 , 则不需要关心 该对象 的内存占用情况 , 在这块代码块作用域结束时 , ( 一般是函数大括号内的代码执行完毕 ) , 该 栈内存 中的 MyClass 对象会被系统自动销毁 ; MyClass

    18820

    【Flutter】Image 组件 ( 加载网络图片 | 加载静态图片 | 加载本地图片 | path_provider 插件 )

    构造函数 | Image.network 构造函数 | Image.asset 构造函数 ) 三、Image.network 构造函数 代码示例 : // 图片组件 , 从网络中加载一张图片 Image.network...width: 200, ), 二、加载静态图片 ---- 加载静态图片步骤 : 先声明图片 , 再使用图片 ; ① 声明图片资源 : 在 pubspec.yaml 中声明图片资源路径 ; ② 访问图片...: 在 dart 文件中使用 AssetImage 类访问图片 ; 配置静态图片 : 注册层次 , assets 按在 flutter 的二级层次中配置 ; flutter: uses-material-design...插件 : 搜索插件 : 在 https://pub.dev/packages 中搜索 path_provider 插件 ; 插件地址 : https://pub.dev/packages/path_provider...配置插件 : 在 pubspec.yaml 中配置插件 ; dependencies: path_provider: ^2.0.1 获取插件 : 点击 pubspec.yaml 中右上角的 Pub

    2K30

    Flutter技术与实战(5)

    在动画结束时,反向执行;在动画反向执行完毕时,重新启动执行。...异步函数 对于一个异步函数来说,其返回时内部执行动作并未结束,因此需要返回一个 Future 对象,供调用者使用。...在使用 Provider 之前,我们首先需要在 pubspec.yaml 文件中添加 Provider 的依赖. dependencies: flutter: sdk: flutter...在 Flutter 中,测试用例的声明包含定义、执行和验证三个部分:定义和执行决定了被测试对象提供的、需要验证的最小可测单元;而验证则需要使用 expect 函数,将最小可测单元的执行结果与预期进行比较...运行测试用例,可以看到,Flutter 在执行完计数器的递增方法后,发现其结果 1 与预期的 2 不匹配,于是报错。

    15.8K30

    Riverpod - flutter 状态管理的应用

    `, 我们可以在享受 hooks 的同时,直接使用`Widget.ref(provider).watch` 来监听变更并自动刷新页面。...## 为什么 Flutter 需要状态管理Flutter 作为优秀的跨端框架,其使用的声明式UI有诸多优势,但嵌套的组件给数据传递带来了极大的挑战。...如果将数据在 组件类的构造函数中携带,并在数层中进行传递,随着代码量的提升,将会极大的增加代码的复杂和易理解程度。...### 举个例子我们可以使用最常见的 Flutter demo 来看, 在初始化完成项目之后,我们便可以看到这个例子```dartclass MyHomePage extends StatefulWidget...#### 组件分离但是 多数情况下, 我们需要渲染的页面,和改变数据的按钮 并不在一个组件中,例如,如果我们将这个按钮单独封装在一个类中。这种情况下,我们应该如何在点击按钮的时候增加数据呢?

    19820

    Flutter完整开发实战详解(十五、全面理解State与Provider)

    这就涉及 Flutter 中 Widget 的实现原理,在之前的篇章我们介绍过,这里我们说两个涉及的概念: Flutter 中的 Widget 在一般情况下,是需要通过 Element 转化为 RenderObject...但是当我们点击 4 中的 setState 时,却发现 3 中 Text 没有发现改变, 这是为什么呢? ?...时,只是执行了 _state.widget = newWidget,而我们通过 _DemoPageState(this.data) 传入的 data ,在传入后执行setState 时并没有改变。...而当 InheritedWidget 被更新时,如下代码所示,_dependents 中的 Element 会被逐个执行 notifyDependent ,最后触发 markNeedsBuild ,这也是为什么当...Provider 的使用指南上,更详细的 Vadaski 的 《Flutter | 状态管理指南篇——Provider》 已经写过,我就不重复写轮子了,感兴趣的可以过去看看。

    3.7K21

    重走Flutter状态管理之路—Riverpod入门篇

    其实Provider在使用上已经非常不错了,只不过随着Flutter的更加深入,大家对它的需求也就越来越高,特别是对Provider中因为InheritedWidget层次问题导致的异常和BuildContext...这个对象允许我们读取其他Provider,在我们Provider的状态将被销毁时执行一些操作,以及其它一些事情 传递给Provider的函数返回的对象的类型,取决于所使用的Provider。...这对于在某个变化发生时执行某些操作是很有用的,比如在发生错误时显示一个snackbar。 ref.listen方法需要2个参数,第一个是Provider,第二个是当状态改变时我们要执行的回调函数。...也不应该在initState和其他State的生命周期内使用它。 ❞ 通过ref.read来读取Provider的状态 ref.read方法是一种在不监听的情况下获取Provider的状态的方法。...它通常用于由用户交互触发的函数中。例如,当用户点击一个按钮时,我们可以使用ref.read来增加一个计数器的值。

    3.2K20

    Flutter Provider状态管理---八种提供者使用分析

    前言 在我们上一篇文章中对Provider进行了介绍以及类结构的说明,最后还写了一个简单的示例,通过上一章节我们对Provider有了一个基本的了解,这一章节我们来说说Provider的8种提供者以及他们的使用区别...Provider Provider是最基本的Provider组件,可以使用它为组件树中的任何位置提供值,但是当该值更改的时候,它并不会更新UI,下面我们给出一个示例 第一步:创建模型 class UserModel...], ), ), ); } } 复制代码 运行结果 FutureProvider 简单来说,FutureProvider用于提供在组件树中准备好使用其值时可能尚未准备好的值...注意: FutureProvider只会重建一次 默认显示初始值 然后显示Future值 最后不会再次重建 第一步:创建模型 这里和Provider不同的是增加了构造函数,以及changeName变成了...方法时会改变UserModel5里面的name,当然我们在实际开发的过程中并不是这么简单,这里只是演示模型依赖时如果使用ProxyProvider import 'package:flutter/material.dart

    4.3K00

    【技术创作101训练营】Flutter Routes 路由应用与封装小结

    ,重点是介绍 Flutter Navigator 的应用与封装; 个人简介:  (Page 3)首先和尚做一个简单的自我介绍;本人 ID 为 阿策小和尚,为什么叫 和尚 呢?...,防止在栈内没有元素时强制 pop 出栈引起异常;而 maybePop 不仅可以判断还可以执行 Pop 出栈操作,可以在实际场景中灵活应用;       (Page 20)和尚再以静态方式和动态方式为维度再次回顾一下...ARouter 的朋友一定会非常了解; 注意:一般采用 home Widget 时,路由表中不设置 / 名称的 root 路由; 3. initialRoute initialRoute...为重要的构造函数,在使用未在 routes 中注册的命名路由时均会在此回调,通过 onGenerateRoute 构造函数进行具体的业务操作或路由守卫等; 5. onUnknownRoute...: 不要为了封装而封装,在合适的位置调用合适的方法;不要盲从; 多学习参考源码和优秀三方库的实践,多观察生命周期函数进行深入理解; 多动手多尝试,注意异常情况判空处理等; 三方库很香,依旧建议先学习基本系统方法

    1.4K102
    领券