2025 最新flutter面试总结

目录

1.Dart是值传递还是引用传递?

2.Flutter 是单引擎还是双引擎

3. StatelessWidget 和 StatefulWidget 在 Flutter 中有什么区别?

4.简述Dart语音特性

5. Navigator 是什么?在 Flutter 中 Routes 是什么?

6、Dart 是不是单线程模型?是如何运行的?

7. 解释 Stateful Widget Lifecycle ?

8.Dart的事件循环的运行遵循以下规则

9. Flutter 是如何实现原生性能和体验的?

10.那么在Dart中如何让你的代码异步执行呢?

11.说一下 Future 和 Future队列 ?

12. 什么是 Flutter tree shaking

13.Future和 Stream Isolate?

14. Spacer 小部件是什么?

15.在flutter里streams是什么?有几种streams?有什么场景用到它?

16. hot restart 和 hot reload 之间的区别是什么?

17.Stream 有哪两种订阅模式?分别是怎么调用的?

18. 为什么构建(build)方法在 State 上而不是在 StatefulWidget 上?

19.什么是StatelessWidget和StatefullWidget?他们之间的区别是什么?

20. 请解释InheritedWidget是什么,并说明它在状态管理中的作用。

21. Provider与其他状态管理解决方案有什么不同?

22. 简述下Bloc模式是什么,以及它的工作原理。

23. 什么是Flutter中的异步编程?有哪些常用的异步编程模式?

24. Flutter中的渲染对象模型(Render Object Model)是什么?他与Widget树有何区别?

25.待补充中... 

谢谢大家!!!

1.Dart是值传递还是引用传递?

dart是值传递
每次调用函数,传递过去的都是对象的内存地址,而不是这个对象的赋值。

2.Flutter 是单引擎还是双引擎

关于使用多个FlutterEngine还是单个FlutterEngine,这实际上取决于你的具体需求和应用场景

1.用单个FlutterEngine来管理多个入口可能是有利的。这种方式可以减少Flutter引擎的创建和销毁次数,从而提高性能并减少资源消耗。尤其是在Flutter页面之间的切换较为频繁时,使用单个FlutterEngine可以避免每次切换时都重新创建Flutter引擎,从而提高应用的响应速度和用户体验。不过,这也可能带来一些复杂性,比如在处理不同页面的生命周期和状态管理时可能需要更多的工作。

2.使用多个FlutterEngine:另一方面,如果你的应用需要在不同的原生页面或视图中嵌入多个独立的Flutter视图,并且这些视图之间需要相互隔离或者具有不同的生命周期,那么使用多个FlutterEngine可能更为合适。这样可以确保每个Flutter视图都有其自己的引擎实例,从而避免潜在的状态冲突和生命周期问题。然而,这也可能带来更高的资源消耗和性能开销。

3. StatelessWidget 和 StatefulWidget 在 Flutter 中有什么区别?


   在 Flutter 中,StatelessWidget 和 StatefulWidget 是两种基本的 Widget 类型,它们的主要区别在于状态管理和如何处理 UI 更新。以下是它们的详细比较:

 StatelessWidget

  定义:

  StatelessWidget 是一种不可变的 Widget,其状态在创建后不会改变。它们只依赖于构造函数中的参数来构建 UI。

特点:

不维护任何内部状态。
适合用于显示静态内容或简单的 UI 结构。
在需要更新 UI 时,必须重新创建该 Widget 的实例。

使用示例:

class MyStatelessWidget extends StatelessWidget {final String title;MyStatelessWidget({required this.title});@overrideWidget build(BuildContext context) {return Text(title);}
}

StatefulWidget

定义:

StatefulWidget 是一种可变的 Widget,可以在其生命周期内维护状态。它可以响应用户输入或其他事件并更新 UI。

特点:

具有一个可变的状态(通过 State 类管理)。
当状态发生变化时,通过调用 setState() 方法来通知 Flutter 更新 UI。
适合用于需要动态更新的内容,如表单、动画等。

使用示例: 

class MyStatefulWidget extends StatefulWidget {@override_MyStatefulWidgetState createState() => _MyStatefulWidgetState();
}class _MyStatefulWidgetState extends State<MyStatefulWidget> {int _counter = 0;void _incrementCounter() {setState(() {_counter++;});}@overrideWidget build(BuildContext context) {return Column(children: [Text('Counter: $_counter'),ElevatedButton(onPressed: _incrementCounter,child: Text('Increment'),),],);}
}

状态管理:

StatelessWidget 不维护任何状态,适合静态内容。
StatefulWidget 可以维护内部状态,适合动态内容。

更新机制:

StatelessWidget 需要重新创建实例来更新 UI。
StatefulWidget 通过 setState() 方法来更新 UI。
根据应用的需求,开发者可以选择使用 StatelessWidget 或 StatefulWidget 来构建相应的界面。

4.简述Dart语音特性

在Dart中,一切都是对象,所有的对象都是继承自Object
Dart是强类型语言,但可以用var或 dynamic来声明一个变量,Dart会自动推断其数据类型,dynamic类似c#

没有赋初值的变量都会有默认值null
Dart支持顶层方法,如main方法,可以在方法内部创建方法
Dart支持顶层变量,也支持类变量或对象变量
Dart没有public protected private等关键字,如果某个变量以下划线(_)开头,代表这个变量在库中是私有的

5. Navigator 是什么?在 Flutter 中 Routes 是什么?

在 Flutter 中,Navigator 和 Routes 是用于管理应用导航和页面切换的核心组件。以下是它们的详细解释:

Navigator

定义:Navigator 是一个 Widget,用于在 Flutter 应用中管理页面的堆栈。它可以通过推送(push)新页面和弹出(pop)当前页面来实现页面的切换。

功能:

页面堆栈管理:Navigator 维护一个页面堆栈,用户可以在不同页面之间导航。
动画效果:Navigator 提供了默认的页面切换动画,可以通过自定义的路由实现更复杂的动画效果。

使用示例:

Navigator.push(context,MaterialPageRoute(builder: (context) => SecondPage()),
);

Routes

定义:Routes 是指应用中的不同页面或屏幕。每个页面都可以通过一个唯一的字符串标识。

类型:

命名路由:Flutter 支持命名路由,可以通过一个字符串直接引用一个路由,而不是创建一个新的 MaterialPageRoute 实例。
默认路由:可以在 MaterialApp 的 routes 参数中定义应用的所有路由。


使用示例: 

MaterialApp(initialRoute: '/',routes: {'/': (context) => HomePage(),'/second': (context) => SecondPage(),},
);// 导航到命名路由
Navigator.pushNamed(context, '/second');

Navigator 是用于管理页面堆栈和导航的 Widget,而 Routes 是用于定义应用中不同页面的结构。通过结合使用 Navigator 和 Routes,Flutter 开发者可以轻松地实现复杂的导航逻辑和用户体验。

6、Dart 是不是单线程模型?是如何运行的?

引用《Flutter中文网》里的话
Dart 在单线程中是以消息循环机制来运行的,其中包含两个任务队列,一个是“微任务队列” microtask queue 另一个是“事件队列” event queue。

7. 解释 Stateful Widget Lifecycle ?

生命周期包含以下简化步骤

createState()  // 创建状态mounted == true  // 是否安装initState()  // 初始化状态didChangeDependencies() // 是否更改了依赖项build()   // 构建didUpdateWidget() // 是否更新小部件setState()  // 设置状态deactivate() // 无效的dispose()  // 释放mounted == false

8.Dart的事件循环的运行遵循以下规则

入口函数 main()执行完后,消息循环机制便启动了。首先会按照先进先出的顺序逐个执行微任务队列中的任务,当所有微任务队列执行完后便开始执行事件队列中的任务,事件任务执行完毕后再去执行微任务,如此循环往复

9. Flutter 是如何实现原生性能和体验的?

Flutter 通过一系列独特的设计和技术实现了原生应用的性能和体验。以下是 Flutter 如何实现原生的几个关键点:

渲染引擎

Skia:Flutter 使用 Skia 作为其渲染引擎。Skia 是一个高性能的 2D 图形库,可以直接与底层操作系统的图形 API 进行交互(如 OpenGL 和 Vulkan),从而实现高效的图形渲染。

直接访问原生 API

Platform Channels:Flutter 通过平台通道(Platform Channels)与原生代码进行通信。开发者可以在 Flutter 中调用原生 Android 或 iOS 的 API,实现对硬件功能(如相机、GPS 等)的访问。

Widget 树

自绘 Widget:Flutter 的 UI 是完全由 Widgets 构成的,Flutter 不依赖于原生 UI 组件,而是通过绘制其自己的组件来实现。从而确保了在不同平台上具有一致的外观和行为。
高效的性能

AOT 编译:

Flutter 使用 Ahead-of-Time (AOT) 编译,将 Dart 代码编译为原生机器码,从而提高应用的启动速度和运行性能。
热重载

开发体验:

Flutter 提供热重载功能,使得开发者在进行 UI 修改时可以立即查看效果,而无需重新启动应用,这大大提高了开发效率。
跨平台

单一代码库:

通过共享单一代码库,Flutter 可以同时为 iOS 和 Android 平台构建应用,减少了开发和维护的成本。
丰富的组件库

Material 和 Cupertino:

Flutter 提供了丰富的 Material Design 和 Cupertino 组件,开发者可以轻松创建符合 Android 和 iOS 平台的原生用户体验。

10.那么在Dart中如何让你的代码异步执行呢?

把要异步执行的代码放在微任务队列或者事件队列里就行了。
可以调用scheduleMicrotask()来让代码以微任务的方式异步执行
可以调用Timer.run来让代码以Event loop的方式异步执行

11.说一下 Future 和 Future队列 ?

Dart中,执行一个异步任务使用Future来处理。在 Dart 的每一个 Isolate 当中,执行的优先级为 :Main > MicroTask > EventQueue
Dart 在单线程中是以消息循环机制来运行的,其中包含两个任务队列,一个是“微任务队列” microtask queue,另一个叫做“事件队列” event queue。

Future 默认情况下其实就是往「事件队列」里插入一个事件,当有空余时间的时候就去执行,当执行完毕后会回调 Future.then(v) 方法。而我们也可以通过使用 Future.microtask 方法来向 「微任务队列」中插入一个任务,这样就会提高他执行的效率。

12. 什么是 Flutter tree shaking

在 Flutter 中,Tree Shaking 是一种优化技术,用于减少最终应用的体积。具体来说,它的作用是:

去除未使用的代码:

在构建应用时,Tree Shaking 会分析代码中的依赖关系,并自动移除那些在应用中未被引用或使用的代码。这包括未使用的库、类、函数等。

提高性能:

通过减小应用的体积,Tree Shaking 帮助提高应用的加载速度和运行性能,因为较少的代码意味着更少的资源消耗。

编译时优化:

Flutter 在编译过程中会进行 Tree Shaking,确保在最终的构建产物中只包含必要的代码。
在编译 Flutter Web 应用程序时,JavaScript 包由 dart2js 编译器生成。发布构建具有最高级别的优化,包括摇树(tree shaking)你的代码。摇树是指通过仅包含保证会执行的代码来消除未使用的代码的过程。这意味着你无需担心应用程序包含的库的大小,因为未使用的类或函数将从编译后的 JavaScript 包中排除。

13.Future和 Stream Isolate?

在 Flutter 中,Future、Stream和Isolate都是用于处理异步任务的重要概念,它们的区别和应用场景如下:

Future:

表示一个异步操作的结果。使用Future可以在异步操作完成后获取到操作的结果。适用于处理单个异步任务并获取最终结果的场景,例如网络请求、文件读写等。

Stream:

表示一个异步的数据流。使用Stream可以处理异步的数据流,例如网络请求的响应数据、传感器数据等。适用于处理连续的异步数据的场景。

Isolate:

是Dart中的线程,代表一个执行环境。不同执行环境(Isolate)之间内存不共享。Dart的异步操作不一定在另一个线程(Isolate)中执行,而且通常是在同一个线程(Isolate)中执行。适用于处理耗时的计算任务、网络请求、处理大量数据等场景。使用Isolate可以提高应用的性能和响应速度。

在实际应用中,可以根据具体的需求选择使用合适的异步方式。例如,如果需要处理单个异步任务并获取最终结果,可以使用Future;如果需要处理异步数据流,可以使用Stream;如果需要在不同的线程中执行异步任务,可以使用Isolate。同时,在使用Isolate时需要注意线程之间的通信和数据传递问题。

14. Spacer 小部件是什么?

Spacer 通过 flex 容器管理小部件之间的空白空间。

通过使用 Row 和 Column 的 MainAxis 对齐方式,我们也可以管理空间。

Row(children: [Text('左边的文本'),Spacer(), // 添加可扩展的空白空间Text('右边的文本'),],
)
| 左边的文本 |        (Spacer)        | 右边的文本 |

15.在flutter里streams是什么?有几种streams?有什么场景用到它?

Stream 用来处理连续的异步操作,Stream 是一个抽象类,用于表示一序列异步数据的源。它是一种产生连续事件的方式,可以生成数据事件或者错误事件,以及流结束时的完成事件
分单订阅流和广播流。
网络状态的监控
stream中执行的异步模式就是StreamMicrotask

16. hot restart 和 hot reload 之间的区别是什么?

在 Flutter 开发中,hot reload 和 hot restart 是两种常用的功能,用于提高开发效率,但它们之间有一些重要的区别:

Hot Reload

定义:hot reload 是一种快速更新代码的方式,它可以在不重启应用的情况下,立即反映对代码的更改。

特点:

保持状态:hot reload 会保留应用的当前状态,包括用户输入、动画等。这样可以在不丢失进度的情况下查看更改。
适合 UI 更改:主要用于更新 UI 方面的代码,如 Widget 的布局或样式。

使用场景:

修改 UI 组件、样式或布局时。
调整 Widget 的属性或添加新的 Widget。

Hot Restart

定义:hot restart 是一种重启应用的方式,它会重新加载整个应用及其状态。

特点:

重置状态:hot restart 会清除当前状态,并重新启动应用,因此所有的状态、数据和输入都会丢失。
适合全局改变:主要用于应用逻辑或状态更改时,需要重新初始化应用。

使用场景:

修改全局状态、依赖项、初始化方法或其他需要重置的逻辑时。
当更改了应用的入口文件或 main() 方法时。

状态保持:

hot reload 保持当前状态。
hot restart 清除当前状态并重启应用。

适用场景:

hot reload 适合快速迭代 UI 更改。
hot restart 适合需要重置应用的全局更改。
通过合理使用这两种功能,Flutter 开发者可以显著提高开发效率和用户体验。

17.Stream 有哪两种订阅模式?分别是怎么调用的?

Stream有两种订阅模式:单订阅(single) 和 多订阅(broadcast)。

单订阅就是只能有一个订阅者,而广播是可以有多个订阅者。这就有点类似于消息服务(Message Service)的处理模式。单订阅类似于点对点,在订阅者出现之前会持有数据,在订阅者出现之后就才转交给它。

而广播类似于发布订阅模式,可以同时有多个订阅者,当有数据时就会传递给所有的订阅者,而不管当前是否已有订阅者存在。

Stream 默认处于单订阅模式,所以同一个 stream 上的 listen 和其它大多数方法只能调用一次,调用第二次就会报错。但 Stream 可以通过 transform() 方法(返回另一个 Stream)进行连续调用。通过 Stream.asBroadcastStream() 可以将一个单订阅模式的 Stream 转换成一个多订阅模式的 Stream,isBroadcast 属性可以判断当前 Stream 所处的模式。

18. 为什么构建(build)方法在 State 上而不是在 StatefulWidget 上?

构建方法放在 State 类中是为了更好地管理和反映状态变化,使得 StatefulWidget 能够动态响应用户交互和其他条件的变化。这种设计使得 Flutter 的状态管理更加高效和灵活。

状态管理

StatefulWidget 允许在其生命周期中维护状态。状态可以随着用户交互或其他因素而变化。因此,构建方法在 State 类中,而不是在 StatefulWidget 中,以便能够反映这些动态变化。


不可变性

StatelessWidget 的所有内容都是不可变的,每次需要更新时都会重新创建一个新的 Widget 实例。这使得它的构建方法可以直接在 Widget 类中定义。

生命周期

在 StatefulWidget 中,状态信息可能会发生变化,这些变化需要在构建方法中反映出来。通过将构建方法放在 State 类中,Flutter 能够在状态变化时仅重建相关的部分,提高性能。

设计逻辑

State 类不仅负责构建 UI,还包含了管理状态的逻辑。将构建方法放在 State 中,可以更清晰地分离出 Widget 的外观(StatefulWidget)和其行为(State)。

说明:

import 'package:flutter/material.dart';void main() {runApp(MyApp());
}class MyApp extends StatelessWidget {@overrideWidget build(BuildContext context) {return MaterialApp(home: CounterWidget(),);}
}class CounterWidget extends StatefulWidget {@override_CounterWidgetState createState() => _CounterWidgetState();
}class _CounterWidgetState extends State<CounterWidget> {int _counter = 0;void _incrementCounter() {setState(() {_counter++;});}@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: Text('Counter Example')),body: Center(child: Column(mainAxisAlignment: MainAxisAlignment.center,children: <Widget>[Text('You have pushed the button this many times:'),Text('$_counter',style: Theme.of(context).textTheme.headline4,),],),),floatingActionButton: FloatingActionButton(onPressed: _incrementCounter,tooltip: 'Increment',child: Icon(Icons.add),),);}
}
CounterWidget (StatefulWidget)|v_CounterWidgetState (State)||--- build()  <-- 构建方法在 State 中|    ||    |--- Scaffold|    |      ||    |      |--- AppBar|    |      |--- Body|    |      |      ||    |      |      |--- Column|    |      |      |      ||    |      |      |      |--- Text (说明)|    |      |      |      |--- Text (计数器)|    |      ||    |      |--- FloatingActionButton||--- _incrementCounter()  <-- 更新状态

CounterWidget 是一个 StatefulWidget,它创建了一个 _CounterWidgetState 的实例。

_CounterWidgetState 中的 build 方法负责创建 UI。当 _counter 的值变化时,调用 setState 方法会触发 build 方法重新构建 UI。

将构建方法放在 State 中,能够确保 UI 始终反映最新的状态变化。

19.什么是StatelessWidget和StatefullWidget?他们之间的区别是什么?

StatelessWidget是一旦构建后状态就不能改变的Widget,无生命周期的回调

StatefulWidget是一旦构建Widget的状态还会发生改变的Widget。

StatefulWidget有一个状态类State,维护了可变状态。当状态发生变化时,StatefulWidget 将会重建其对应的 State 对象。

生命周期不同,调用build()方法次数和时机不同。

20. 请解释InheritedWidget是什么,并说明它在状态管理中的作用。

InheritedWidget 类是一个特殊的无界面(stateless)Widget,它主要用于在整个Widget树中`自顶向下`地高效传递和共享数据(`Notifation`用于`自下而上`传递数据)。

InheritedWidget能够提供数据在widget树中从上到下进行传递。保证数据在不同子widget中进行共享

作用
1、数据共享
2、数据监听与重建
3、性能优化:只重绘受影响的部分子树

21. Provider与其他状态管理解决方案有什么不同?

provider是基于InheritedWidget的包装,可以实现页面和其子页面间的数据共享

Provider具有缓存功能,调用setState()方法,那些没有依赖状态的子节点都不会被重新build
https://blog.51cto.com/u_16175630/7445520

22. 简述下Bloc模式是什么,以及它的工作原理。

BLoC全称(Business Logic Component)是谷歌提出的一种设计模式,利用流的方式实现界面的异步渲染和重绘,我们可以非常快速的通过BLoC实现业务与界面的分离。
BLoC 管理着事件 events 和状态 state,比如,它接受一系列事件流,并将它们转化为状态流作为输出。

在Flutter中实现BLoC设计模式需要借助 flutter_bloc 这个库来完成

原理:

BLoC基于流(Stream)的概念,使用RxDart库中的StreamController和Stream来实现。BLoC将UI层(如widget)中的用户操作通过事件(Event)发送给业务逻辑层,并根据这些事件处理数据并生成新的状态(State),再将新状态传递回UI层以更新视图。

23. 什么是Flutter中的异步编程?有哪些常用的异步编程模式?

Flutter中的异步是向事件队列插入任务

Future、Stream

Future一次只支持一个任务,Stream可以支持多个任务

async和await、await for是异步的语法糖

24. Flutter中的渲染对象模型(Render Object Model)是什么?他与Widget树有何区别?

RenderObject就是渲染树中的一个对象,负责布局及绘制

widget负责描述UI,存储配置信息

25.待补充中... 

谢谢大家!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/893555.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HarmonyOS Next构建工具 lycium 原理介绍

HarmonyOS Next构建工具 lycium 原理介绍 背景介绍 HarmonyOS Next中很多系统API是以C接口提供&#xff0c;如果要使用C接口&#xff0c;必须要使用NAPI在ArkTS与C间交互&#xff0c;这种场景在使用DevEco-Studio中集成的交叉编译工具&#xff0c;以及cmake构建工具就完全够用…

【远程视频必备】Briefing:安全视频群聊让远程办公无忧

文章目录 前言1.关于briefing2.本地部署briefing3.使用briefing4.cpolar内网穿透工具安装5.创建远程连接公网地址6.固定briefing公网地址 前言 对于有远程办公或者身处异地与家人好友视频聊天需求的人来说&#xff0c;在享受高效沟通的同时&#xff0c;也或多或少会有对信息泄…

热更新杂乱记

热更新主要有一个文件的MD5值的比对过程&#xff0c;期间遇到2个问题&#xff0c;解决起来花费了一点时间 1. png 和 plist 生成zip的时候再生成MD5值会发生变动。 这个问题解决起来有2种方案&#xff1a; &#xff08;1&#xff09;.第一个方案是将 png和plist的文件时间改…

Elementor Pro 3.27 汉化版 2100套模板 安装教程 wordpress主题中文编辑器插件免费下载

插件下载地址 https://a5.org.cn/a5ziyuan/732506.html 转载请注明出处! Elementor Pro 是流行的 Elementor 的付费扩展 WordPress 页面构建器插件. 它为免费的 Elementor 插件添加了许多附加功能和增强功能&#xff0c;使其成为创建美丽的更强大的工具 WordPress 网站。 如果…

计算机工程:解锁未来科技之门!

计算机工程与应用是一个充满无限可能性的领域。随着科技的迅猛发展&#xff0c;计算机技术已经深深渗透到我们生活的方方面面&#xff0c;从医疗、金融到教育&#xff0c;无一不在彰显着计算机工程的巨大魅力和潜力。 在医疗行业&#xff0c;计算机技术的应用尤为突出。比如&a…

AT8870单通道直流电机驱动芯片

AT8870单通道直流电机驱动芯片 典型应用原理图 描述 AT8870是一款刷式直流电机驱动器&#xff0c;适用于打印机、电器、工业设备以及其他小型机器。两个逻辑输入控制H桥驱动器&#xff0c;该驱动器由四个N-MOS组成&#xff0c;能够以高达3.6A的峰值电流双向控制电机。利用电流…

Vue2.0+ElementUI实现查询条件展开和收起功能组件

一、需求 el-form如果查询条件过多&#xff0c;影响页面的展示效果。查询条件表单是我们系统中非常常见的功能&#xff0c;我们需要把它封装成一个通用的组件&#xff0c;方便在系统开发中提升开发效率。除了在实现基本查询条件的功能上&#xff0c;还需要实现多条件的折叠和展…

Scrapy之一个item包含多级页面的处理方案

目标 在实际开发过程中&#xff0c;我们所需要的数据往往需要通过多个页面的数据汇总得到&#xff0c;通过列表获取到的数据只有简单的介绍。站在Scrapy框架的角度来看&#xff0c;实际上就是考虑如何处理一个item包含多级页面数据的问题。本文将以获取叶子猪网站的手游排行榜及…

MySQL8【学习笔记】

第一章前提须知 1.1 需要学什么 Dbeaver 的基本使用SQL 语句&#xff1a;最重要的就是查询&#xff08;在实战的时候&#xff0c;你会发现我们做的绝大部分工作就是 “查询”&#xff09;MySQL 存储过程&#xff08;利用数据库底层提供的语言&#xff0c;去进行业务逻辑的封装…

【JVM】垃圾收集器详解

你将学到 1. Serial 收集器 2. ParNew 收集器 3. Parallel Scavenge 收集器 4. Serial Old 收集器 5. Parallel Old 收集器 6. CMS 收集器 7. G1 收集器 在 Java 中&#xff0c;垃圾回收&#xff08;GC&#xff09;是自动管理内存的一个重要机制。HotSpot JVM 提供了多种…

SOME/IP服务接口

本系列文章将分享我在学习 SOME/IP 过程中积累的一些感悟&#xff0c;并结合 SOME/IP 的理论知识进行讲解。主要内容是对相关知识的梳理&#xff0c;并结合实际代码展示 SOME/IP 的使用&#xff0c;旨在自我复习并与大家交流。文中引用了一些例图&#xff0c;但由于未能找到原作…

编写0号中断的处理程序

实验内容、程序清单及运行结果 编写0号中断的处理程序&#xff08;课本实验12&#xff09; 解&#xff1a; assume cs:code code segment start: mov ax,cs mov ds,ax mov si,offset do mov ax,0 mov es,ax mov di,200h mov cx,offset doend-offset do ;安装中断例…

Android系统开发(十五):从 60Hz 到 120Hz,多刷新率进化简史

引言 欢迎来到“帧率探索实验室”&#xff01;今天&#xff0c;我们要聊聊 Android 11 中对多种刷新率设备的支持。你可能会问&#xff1a;“这和我写代码有什么关系&#xff1f;”别急&#xff0c;高刷新率不仅仅让屏幕更顺滑&#xff0c;还会直接影响用户体验。想象一下&…

基于JAVA的微信点餐小程序设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…

ChatGPT结合Excel辅助学术数据分析详细步骤分享!

目录 一.Excel在学术论文中的作用✔ 二.Excel的提示词✔ 三. 编写 Excel 命令 四. 编写宏 五. 执行复杂的任务 六. 将 ChatGPT 变成有用的 Excel 助手 一.Excel在学术论文中的作用✔ Excel作为一种广泛使用的电子表格软件&#xff0c;在学术论文中可以发挥多种重要作用&a…

国内有哪些著名的CRM系统提供商?

嘿&#xff0c;你有没有想过&#xff0c;在这个信息爆炸的时代里&#xff0c;企业怎么才能更好地管理客户关系呢&#xff1f;答案就是使用高效的CRM系统。今天我就来给大家聊聊那些在国际上非常有名的CRM系统提供商吧。 悟空CRM 首先不得不提的就是悟空CRM了&#xff01;这可…

Linux中的几个基本指令(二)

文章目录 1、cp指令例一&#xff1a;例二&#xff1a;例三&#xff1a;例四&#xff1a;例五&#xff1a; 2、mv 指令例一&#xff1a;例二&#xff1a; 3、cat指令例一&#xff1a; 4、tac指令5、which指令6、date指令时间戳&#xff1a;7、zip指令 今天我们继续学习Linux下的…

mock可视化生成前端代码

介绍&#xff1a;mock是我们前后端分离的必要一环、ts、axios编写起来也很麻烦。我们就可以使用以下插件&#xff0c;来解决我们的问题。目前支持vite和webpack。&#xff08;配置超级简单&#xff01;&#xff09; 欢迎小伙伴们提issues、我们共建。提升我们的开发体验。 vi…

9. 神经网络(一.神经元模型)

首先&#xff0c;先看一个简化的生物神经元结构&#xff1a; 生物神经元有多种类型&#xff0c;内部也有复杂的结构&#xff0c;但是可以把单个神经元简化为3部分组成&#xff1a; 树突&#xff1a;一个神经元往往有多个树突&#xff0c;用于接收传入的信息。轴突&#xff1a;…

Web 音视频(二)在浏览器中解析视频

前言 浏览器中已经能直接播放视频&#xff0c;为什么还需要手动写代码解析&#xff1f; 因为&#xff0c;某些场景需要对视频进行更细致的处理&#xff0c;比如截取关键帧、提取视频中的文字、人物打码、极低延时播放视频等等。 总之&#xff0c;除了最单纯的视频播放外&…