当前位置: 首页 > news >正文

Android学习总结之jetpack组件间的联系

在传统安卓开发中,UI 组件(Activity/Fragment)常面临三个核心问题:

  1. 生命周期混乱:手动管理 UI 与数据的绑定 / 解绑,易导致内存泄漏(如 Activity 销毁后回调仍在触发)。
  2. 数据断层:配置变更(如屏幕旋转)导致 UI 重建时数据丢失,需重复加载。
  3. 代码冗余:手动通过findViewById绑定 UI 元素,通过setOnClickListener处理交互,样板代码繁杂。

一、Lifecycle:生命周期管理的基石

核心作用:Lifecycle:划定 “安全操作区间”

所有组件的行为都被 Lifecycle 的状态机严格约束:

  • UI 组件(Activity/Fragment)实现LifecycleOwner,暴露自身生命周期(通过getLifecycle()获取Lifecycle对象)。
  • ViewModel:在创建时通过ViewModelProvider与 UI 组件的 Lifecycle 绑定,仅在组件 “非销毁周期”(即从onCreate到最终onDestroy,而非每次重建)内存活。例如,屏幕旋转时 Activity 重建,ViewModel 会被缓存,直到用户真正退出页面。
  • LiveData:通过observe(LifecycleOwner, observer)绑定生命周期,仅在 UI 处于活跃状态(STARTED/RESUMED)时通知数据变化。当 UI 进入 STOPPED 或 DESTROYED,自动断开连接,避免回调到已销毁的组件。
  • Data Binding:若在布局中声明android:lifecycleOwner,生成的绑定类会监听该 LifecycleOwner 的状态,自动为 LiveData 注册 / 注销监听器,确保绑定关系随生命周期同步建立与销毁。
与其他组件的关系
  1. ViewModel 的生命周期绑定
    ViewModel 的存在周期与组件(如 Activity)的 “非销毁性” 生命周期 绑定(即从创建到组件永久销毁,而非每次重建)。

    • ViewModel 通过实现 LifecycleOwner(或依赖 Lifecycle 对象),确保在组件销毁(如因配置变更重建 Activity)时不会被立即回收,而是等待组件真正终止(如用户退出应用)。
    • 底层依赖 LifecycleRegistry 监听组件的 onDestroy 事件,触发 ViewModel 的清理逻辑(如释放资源)。
  2. LiveData 的生命周期感知
    LiveData 的数据订阅必须关联 LifecycleOwner(如 Activity/Fragment),确保仅在组件处于 活跃状态(STARTED/RESUMED)时接收数据更新,避免在组件销毁后回调导致的内存泄漏。

    • LiveData 内部通过 LifecycleBoundObserver 监听 Lifecycle 状态变化,当组件进入 STOPPED 或 DESTROYED 时,自动移除订阅。
  3. Data Binding 的生命周期感知
    Data Binding 生成的绑定类若关联 LifecycleOwner(如在布局中声明 android:lifecycleOwner),可感知组件生命周期,确保绑定的数据观察者(如 LiveData)在合适时机注册 / 注销,避免无效更新。

二、ViewModel:数据与逻辑的载体

核心作用:生命周期与 UI 解耦
  • 数据持久化:当 Activity 因配置变更重建时,ViewModel 不会被销毁(存储在ViewModelStore中),避免重复发起网络请求或重新加载数据。例如,用户旋转屏幕后,ViewModel 中缓存的userData仍可用,直接通过 LiveData 通知新的 Activity 实例更新 UI。
  • 逻辑封装:ViewModel 持有 LiveData 作为数据源,封装业务逻辑(如处理网络响应、数据转换),但不持有 UI 引用(仅依赖 LifecycleOwner 的生命周期),避免内存泄漏。例如,ViewModel 中发起一个协程请求数据,协程会在 ViewModel 销毁时自动取消(通过ViewModelCoroutineScope)。
  • 与 Lifecycle 的绑定:ViewModel 的创建由ViewModelProvider完成,该类会读取 UI 组件的 Lifecycle,当 Lifecycle 进入ON_DESTROY(且组件非因配置变更销毁,如用户按返回键)时,触发 ViewModel 的onCleared()方法,用于释放资源(如关闭流、取消订阅)。
与其他组件的关系
  1. 持有 LiveData 作为数据源
    ViewModel 通常将数据暴露为 LiveData 对象,供 UI 层(通过 Data Binding 或手动订阅)观察。

    • LiveData 的生命周期感知特性确保 ViewModel 中的数据仅在 UI 活跃时更新,ViewModel 自身无需关心 UI 组件的销毁状态。
    • 示例:
      class UserViewModel : ViewModel() {val userData = MutableLiveData<User>() // ViewModel 持有 LiveData
      }
      
  2. 与 Data Binding 的集成
    Data Binding 可直接在布局中引用 ViewModel 的属性(包括 LiveData),通过 <variable name="viewModel" type="UserViewModel" /> 声明后,UI 元素可绑定为 android:text="@{viewModel.userData.name}"

    • 本质上,Data Binding 生成的绑定类会自动为 LiveData 注册监听器,当数据变化时触发 UI 刷新。
  3. 依赖 Lifecycle 实现生命周期安全
    ViewModel 通过 ViewModelProvider 创建时,会关联组件的 Lifecycle,确保自身在组件的非销毁周期内存活。

    • 底层通过 ViewModelStore 与 Lifecycle 的 ON_DESTROY 事件联动,在组件真正销毁时释放资源。

三、LiveData:数据变化的响应式桥梁

核心作用
  • 生命周期感知订阅observe()方法必须传入 LifecycleOwner,内部通过LifecycleBoundObserver监听生命周期状态。例如,当 Activity 进入后台(STOPPED 状态),LiveData 暂停发送更新;Activity 回到前台(RESUMED),自动恢复发送。这避免了后台页面接收无效数据,节省电量和性能。
  • 数据变化的响应式分发:ViewModel 通过postValue()(子线程)或setValue()(主线程)更新数据,LiveData 会检查所有订阅的 LifecycleOwner 是否处于活跃状态,仅通知活跃的 UI 组件。例如,多个 Fragment 订阅同一个 LiveData,当数据变化时,只有可见的 Fragment 会收到通知。
与其他组件的关系
  1. ViewModel 与 UI 之间的 “粘合剂”

    • ViewModel 使用 MutableLiveData 存储可变数据,通过 LiveData(不可变引用)暴露给 UI 层,实现数据的单向流动(ViewModel → UI)。
    • UI 层(Activity/Fragment)通过 Data Binding 或 observe() 方法订阅 LiveData,当数据变化时自动更新 UI。
  2. 依赖 Lifecycle 实现安全订阅
    LiveData.observe() 必须传入 LifecycleOwner,内部通过 LifecycleRegistry 判断组件状态:

    • 当组件处于 DESTROYED 状态(如 Activity 真正退出),自动移除订阅,避免持有过期的 UI 引用。
    • 当组件因配置变更(如旋转屏幕)重建时,新的 UI 组件会重新订阅 LiveData,而 ViewModel 中的数据保持不变,实现无缝衔接。
  3. 与 Data Binding 的深度集成
    Data Binding 支持直接绑定 LiveData 对象,生成的绑定类会自动为 LiveData 添加 Observer,无需手动编写 observe() 代码。

    • 例如,布局中 android:text="@{viewModel.userData.name}" 会被解析为对 userData 的监听,数据变化时触发 TextView 的更新。

四、Data Binding:UI 与数据的自动化粘合剂

核心作用
  • 静态绑定:直接映射 ViewModel 的普通属性(如android:text="@{viewModel.username}"),当属性变化时(需实现BaseObservable或使用 Kotlin 的ObservableField),自动调用notifyPropertyChanged()更新 UI。
  • 动态绑定 LiveData:无需手动调用observe(),Data Binding 生成的绑定类会自动为 LiveData 添加观察者。例如,布局中android:text="@{viewModel.userData.name}"会被解析为对userData的监听,当userData变化时,自动更新 TextView 的文本。
  • 双向绑定:通过@={}语法(如android:text="@={viewModel.searchQuery}"),实现 UI 与 ViewModel 的双向同步。本质上,Data Binding 为 EditText 设置onTextChangedListener,当用户输入时,自动将值赋给 ViewModel 的字段(需为MutableLiveData或可观察属性),形成 “UI→ViewModel→LiveData→UI” 的闭环。
与其他组件的关系
  1. 绑定 ViewModel 的属性(包括 LiveData)

    • 在布局中声明 ViewModel 类型的变量后,可直接引用其普通属性或 LiveData 对象。
    • 对于 LiveData,Data Binding 会自动处理订阅和取消订阅,确保与组件生命周期同步。
  2. 依赖 Lifecycle 实现监听清理
    当 Data Binding 的根布局声明了 android:lifecycleOwner="@{viewModel}"(或关联的 Activity/Fragment),绑定类会感知生命周期,在组件销毁时自动解绑,避免内存泄漏。

  3. 双向绑定与 ViewModel 的交互
    通过 @={} 语法支持双向绑定(如 EditText 的输入同步到 ViewModel 的字段),本质上是为 UI 元素设置监听器,并将变化通知给 ViewModel,形成数据的双向流动(UI ↔ ViewModel)。

    • 双向绑定的字段通常为 LiveData 或普通可变属性,结合 ViewModel 实现业务逻辑的解耦。

五、四者协作的核心流程

  1. 生命周期驱动初始化

    • Activity/Fragment 创建时,Lifecycle 状态变为 CREATED,触发 ViewModel 的创建(通过 ViewModelProvider),ViewModel 与组件的 Lifecycle 绑定。
    • Data Binding 初始化,生成绑定类并关联 ViewModel,布局中的 LiveData 绑定自动注册监听(基于 LifecycleOwner)。
  2. 数据变化触发 UI 更新

    • ViewModel 中的业务逻辑更新 MutableLiveData(如 userData.value = newUser)。
    • LiveData 检测到数据变化,通过 LifecycleBoundObserver 检查关联的 LifecycleOwner 是否处于活跃状态,若活跃则通知 Data Binding 生成的绑定类。
    • 绑定类更新对应的 UI 元素(如 TextView 的文本、ImageView 的图片),无需手动调用 findViewById() 或设置回调。
  3. 生命周期结束时的资源释放

    • 当 Activity/Fragment 进入 DESTROYED 状态,Lifecycle 通知 ViewModel 清理资源(如取消未完成的协程),LiveData 自动移除所有订阅,Data Binding 解绑所有 UI 引用,确保无内存泄漏。
扩展总结:
  1. 底层支撑:Lifecycle
    为所有组件提供统一的生命周期 “时钟”,定义何时可以安全地进行数据操作(如 LiveData 发送更新)、何时需要释放资源(如 ViewModel 清理内存)。没有 Lifecycle,其他组件的生命周期安全将无法保障。

  2. 数据层:ViewModel + LiveData

    • ViewModel 作为 “数据管理者”,持有 LiveData 并封装业务逻辑,确保数据在生命周期内稳定存在。
    • LiveData 作为 “数据传输者”,依托 Lifecycle 的状态判断,将数据精准推送给活跃的 UI,避免无效通信。
  3. UI 层:Data Binding
    作为连接数据与 UI 的 “桥梁”,通过编译时生成的代码,将 ViewModel 和 LiveData 的状态直接映射到 UI 元素,消除手动操作的样板代码,同时借助 Lifecycle 自动管理绑定关系,避免内存泄漏。

六、登录实战解析

以 “用户登录” 场景为例,看四者如何协同工作:

  1. 初始化阶段
    • Activity 创建,Lifecycle 状态变为CREATED,通过ViewModelProvider获取LoginViewModel(ViewModel 与 Activity 的 Lifecycle 绑定)。
    • Data Binding 初始化,解析布局文件,发现viewModel变量,生成ActivityLoginBinding类,绑定 ViewModel 到 UI 元素(如用户名输入框、登录按钮)。
    • 布局中android:text="@{viewModel.errorMsg}"触发 Data Binding 为errorMsg(LiveData)自动注册观察者,该观察者关联 Activity 的 Lifecycle,仅在 Activity 活跃时接收错误信息。
  2. 用户交互阶段

    • 用户点击登录按钮,Data Binding 通过双向绑定获取输入的账号密码,触发 ViewModel 的login()方法。
    • ViewModel 中,login()发起网络请求(如协程),成功后更新userData(MutableLiveData)的值:userData.value = loginResult
    • LiveData 检测到数据变化,遍历所有订阅的 LifecycleOwner(当前 Activity 处于 RESUMED 状态,为活跃状态),通知 Data Binding 生成的绑定类更新 UI(如跳转到主页)。
  3. 配置变更阶段(如屏幕旋转)

    • Activity 销毁并重建,Lifecycle 经历DESTROYEDCREATED
    • ViewModel 因绑定 Activity 的 “非销毁周期”,被ViewModelStore缓存,userData中的数据(如登录状态)保持不变。
    • 新 Activity 通过ViewModelProvider获取到缓存的 ViewModel,Data Binding 重新绑定 UI,LiveData 自动向新 Activity 的 LifecycleOwner 注册订阅,UI 无需重新加载数据即可恢复状态。
  4. 资源释放阶段

    • 用户退出页面,Activity 进入DESTROYED状态,Lifecycle 通知 ViewModel 调用onCleared(),释放协程等资源。
    • LiveData 检测到所有订阅的 LifecycleOwner 处于 DESTROYED,自动移除所有观察者,避免持有 Activity 引用。
    • Data Binding 解绑所有 UI 元素与数据的连接,回收内存,确保无泄漏。

七、总结:四者的核心关系图

UI 组件(Activity/Fragment)
│
├─ 实现 LifecycleOwner(提供 Lifecycle)
│
├─ 通过 ViewModelProvider 获取 ViewModel(绑定 Lifecycle)
│  └─ ViewModel 持有 MutableLiveData(数据载体)
│
├─ Data Binding 绑定 ViewModel(布局中声明 @{viewModel.data})
│  └─ 生成的绑定类自动订阅 LiveData(基于 LifecycleOwner)
│
└─ LiveData.observe() 关联 LifecycleOwner└─ 数据变化时,通过 Lifecycle 过滤无效状态,通知 UI 更新

这四个组件通过 生命周期感知 和 数据驱动 形成闭环:

  • Lifecycle 确保所有组件的生命周期安全;
  • ViewModel 封装数据与逻辑,隔离 UI 与业务;
  • LiveData 实现数据的响应式分发,避免无效更新;
  • Data Binding 简化 UI 与数据的绑定,减少样板代码。

相关文章:

Android学习总结之jetpack组件间的联系

在传统安卓开发中&#xff0c;UI 组件&#xff08;Activity/Fragment&#xff09;常面临三个核心问题&#xff1a; 生命周期混乱&#xff1a;手动管理 UI 与数据的绑定 / 解绑&#xff0c;易导致内存泄漏&#xff08;如 Activity 销毁后回调仍在触发&#xff09;。数据断层&am…...

linux的信号量初识

Linux下的信号量(Semaphore)深度解析 在多线程或多进程并发编程的领域中&#xff0c;确保对共享资源的安全访问和协调不同执行单元的同步至关重要。信号量&#xff08;Semaphore&#xff09;作为经典的同步原语之一&#xff0c;在 Linux 系统中扮演着核心角色。本文将深入探讨…...

【安装指南】Centos7 在 Docker 上安装 RabbitMQ4.0.x

目录 前置知识:RabbitMQ 的介绍 一、单机安装 RabbitMQ 4.0.7版本 1.1 在线拉取镜像 二、延迟插件的安装 2.1 安装延迟插件 步骤一:下载延迟插件 步骤二:将延迟插件放到插件目录 步骤三:启动延迟插件 步骤四:重启 RabbitMQ 服务 步骤五:验收成果 步骤六:手动…...

Android和iOS测试的区别有哪些?

作为移动端测试工程师,Android 和 iOS 的测试差异直接影响测试策略设计。本文从测试环境、工具链、兼容性、发布流程等维度全面解析,并附实战建议。 1. 测试环境差异 维度AndroidiOS设备碎片化高(厂商/分辨率/系统版本多样)低(仅苹果设备,版本集中)系统开放性开放(可Ro…...

spring中的@PostConstruct注解详解

基本概念 PostConstruct 是 Java EE 规范的一部分&#xff0c;后来也被纳入到 Spring 框架中。它是一个标记注解&#xff0c;用于指示一个方法应该在依赖注入完成后被自动调用。 主要特点 生命周期回调&#xff1a;PostConstruct 标记的方法会在对象初始化完成、依赖注入完成…...

大模型开发学习笔记

文章目录 大模型基础大模型的使用大模型训练的阶段大模型的特点及分类大模型的工作流程分词化(tokenization)与词表映射 大模型的应用 进阶agent的组成和概念planning规划子任务分解ReAct框架 memory记忆Tools工具\工具集的使用langchain认知框架ReAct框架plan-and-Execute计划…...

【android Framework 探究】pixel 5 内核编译

相关文章&#xff1a; 【android Framework 探究】android 13 aosp编译全记录 【android Framework 探究】android 13 aosp 全记录 - 烧录 一&#xff0c;环境 主机 -> Ubuntu 18.04.6 LTS 内存 -> 16GB 手机 -> pixel 5 代号redfin。kernel代号redbull 二&#xf…...

PowerBI实现点击空白处隐藏弹窗(详细教程)

PowerBI点击空白处隐藏弹窗 第五届PowerBI可视化大赛中亚军作品:金融企业智慧经营分析看板 有个功能挺好玩的&#xff1a;点击空白处隐藏弹窗&#xff0c;gif动图如下&#xff1a; 我们以一个案例分享下实现步骤&#xff1a; 第一步&#xff0c; 先添加一个显示按钮&#xff…...

【git】获取特定分支和所有分支

1 特定分支 1.1 克隆指定分支&#xff08;默认只下载该分支&#xff09; git clone -b <分支名> --single-branch <仓库URL> 示例&#xff08;克隆 某一个 分支&#xff09;&#xff1a; git clone -b xxxxxx --single-branch xxxxxxx -b &#xff1a;指定分支…...

Windows配置grpc

Windows配置grpc 方法一1. 使用git下载grph下载速度慢可以使用国内镜像1.1 更新子模块 2. 使用Cmake进行编译2.1 GUI编译2.2 命令行直接编译 3. 使用Visual Studio 生成解决方法 方法二1. 安装 vcpkg3.配置vckg的环境变量2. 使用 vcpkg 安装 gRPC3. 安装 Protobuf4. 配置 CMake…...

【学习笔记】深入理解Java虚拟机学习笔记——第2章 Java内存区域与内存溢出异常

第2章 Java内存区域与内存溢出异常 2.1 概述 略 2.2 运行时数据区域 2.2.1 程序计数器 线程私有&#xff0c;记录执行的字节码位置 2.2.2 Java 虚拟机栈 线程私有&#xff0c;存储一个一个的栈帧&#xff0c;通过栈帧的出入栈来控制方法执行。 -栈帧&#xff1a;对应一个…...

数字智慧方案6189丨智慧应急综合解决方案(46页PPT)(文末有下载方式)

资料解读&#xff1a;智慧应急综合解决方案 详细资料请看本解读文章的最后内容。 在当前社会环境下&#xff0c;应急管理的重要性愈发凸显。国务院发布的《“十四五” 国家应急体系规划》以及 “十四五” 智慧应急专项规划&#xff0c;明确了应急管理体系建设的方向和重点&…...

解决 3D Gaussian Splatting 中 SIBR 可视化组件报错 uv_mesh.vert 缺失问题【2025最新版!】

一、&#x1f4cc; 引言 在使用 3D Gaussian Splatting&#xff08;3DGS&#xff09;进行三维重建和可视化的过程&#xff0c;SIBR_gaussianViewer_app 是一款官方推荐的本地可视化工具&#xff0c;允许我们在 GPU 上实时浏览重建结果。然而&#xff0c;许多用户在启动该工具时…...

见多识广4:Buffer与Cache,神经网络加速器的Buffer

目录 前言传统意义上的Buffer与Cache一言以蔽之定义与主要功能BufferCache 数据存储策略二者对比 神经网络加速器的bufferInput BufferWeight BufferOutput Buffer与传统buffer的核心区别总结 前言 知识主要由Qwen和Kimi提供&#xff0c;我主要做笔记。 参考文献&#xff1a; …...

微服务中组件扫描(ComponentScan)的工作原理

微服务中组件扫描(ComponentScan)的工作原理 你的问题涉及到Spring框架中ComponentScan的工作原理以及Maven依赖管理的影响。我来解释为什么能够扫描到common模块的bean而扫描不到其他模块的bean。 根本原因 关键在于**类路径(Classpath)**的包含情况&#xff1a; Maven依赖…...

C++之类和对象基础

⾯向对象三⼤特性&#xff1a;封装、继承、多态 类和对象 一.类的定义1. 类的定义格式2.类域 二.实例化1.对象2.对象的大小 三.this指针 在 C 的世界里&#xff0c;类和对象构成了面向对象编程&#xff08;Object-Oriented Programming&#xff0c;OOP&#xff09;的核心框架&…...

【DIY小记】新手小白超频遇到黑屏问题解决分享

最近玩FPS游戏的时候&#xff0c;发现以前一顿操作超频之后的电脑&#xff0c;有一定概率会出问题。具体表现比如一种是&#xff0c;电脑显示器直接黑屏&#xff0c;所有键盘交互没有响应&#xff0c;只能直接重启电脑&#xff0c;还有一种是偶现卡顿&#xff0c;直接死机或者卡…...

虚幻引擎 IK Retargeter 编辑器界面解析

我来为您详细解释这段关于虚幻引擎IK Retargeter编辑器界面的文本&#xff0c;它描述了动画重定向系统的核心组件和工作原理。 Retarget Phases (重定向阶段) 这部分介绍了动画重定向过程中的三个关键计算阶段&#xff0c;每个阶段都可以单独启用或禁用&#xff0c;这对于调试…...

uc系统中常用命令、标准C库函数和系统调用

目录 一、常用命令 env echo $name 键值 export name unset name gcc -c xxx.c ar 命令 ar -r libxxx.a xxx1.o xxx2.o gcc -c -fpic xxx.c gcc -shared -fpic xxx1.c xxx2.c -o libxxx.so kill [-信号] PID kill -l 软链接&#xff1a;ln -s xxx yyy 硬链接&…...

OpenHarmony - 驱动使用指南,HDF驱动开发流程

OpenHarmony - HDF驱动开发流程 概述 HDF&#xff08;Hardware Driver Foundation&#xff09;驱动框架&#xff0c;为驱动开发者提供驱动框架能力&#xff0c;包括驱动加载、驱动服务管理、驱动消息机制和配置管理。并以组件化驱动模型作为核心设计思路&#xff0c;让驱动开发…...

C++负载均衡远程调用学习之UDP SERVER功能

目录 1.LARSV0.9-配置功能 2.LARSV0.10-upd-server的实现 3.LARSV0.10-udp-client的实现 1.LARSV0.9-配置功能 2.LARSV0.10-upd-server的实现 3.LARSV0.10-udp-client的实现...

word交叉引用图片、表格——只引用编号的处理方法

交叉引用图片/表格 在“引用”选项卡上的“题注”组中&#xff0c;单击“插入题注”。勾选【从题注中排除标签】。在文中插入题注。 【注 意】 这时候插入的题注只有编号项了。然后手动打上标签【TABLE】&#xff0c;并在标签和编号项之间加上【样式分隔符&#xff0c;AltCt…...

平台介绍-开放API接口-鉴权

平台的理念是一个组织内部只建一套系统。但是现实情况是&#xff0c;组织内部已经建立了很多系统&#xff0c;是不能一次性替代的&#xff0c;只能先搭起平台&#xff0c;然后逐步开始替换。这样就不可避免的存在其他系统和平台进行交互的问题。 平台为此设计了开放API接口。其…...

【Bootstrap V4系列】 学习入门教程之 组件-警告框(Alert)

Bootstrap V4 学习入门教程之 组件-警告框&#xff08;Alert&#xff09; 警告框&#xff08;Alert&#xff09;一、示例二、链接的颜色三、添加其它内容四、关闭警告框 通过 JavaScript 触发行为触发器本组件所暴露的事件 警告框&#xff08;Alert&#xff09; 通过精炼且灵活…...

【服务器通信-socket】——int socket(int domain, int type, int protocol);

#include <sys/types.h> #include <sys/socket.h> int socket(int domain, int type, int protocol); domain: AF_INET 这是大多数用来产生socket的协议&#xff0c;使用TCP或UDP来传输&#xff0c;用IPv4的地址 AF_INET6 与上面类似&#xff0c;不过是来用IPv6的地…...

洛谷P1014(Cantor 表[NOIP 1999 普及组])题解

题目大意&#xff1a;求Cantor表&#xff08;按照Z字形排列&#xff08;如第一项是1/1&#xff0c;然后是1/2&#xff0c;2/1&#xff0c;3/1&#xff0c;2/2&#xff09;&#xff09;的第N项。 那么&#xff0c;我们需要找出Cantor表的排列规律。根据题目中的Z字形描述&#x…...

【愚公系列】《Manus极简入门》012-自我认知顾问:“内在探索向导”

&#x1f31f;【技术大咖愚公搬代码&#xff1a;全栈专家的成长之路&#xff0c;你关注的宝藏博主在这里&#xff01;】&#x1f31f; &#x1f4e3;开发者圈持续输出高质量干货的"愚公精神"践行者——全网百万开发者都在追更的顶级技术博主&#xff01; &#x1f…...

密码学_加密

目录 密码学 01 密码基础进制与计量 02 加解密基操 替换 移位 编码 编码 置换 移位 加解密强度 03 对称加密算法(私钥) 工作过程 缺陷 对称加密算法列举&#xff1f; DES DES算法架构 DES分组加密公式 DES中ECB-CBC两种加密方式 3DES 由于DES密钥太短&#xf…...

w317汽车维修预约服务系统设计与实现

&#x1f64a;作者简介&#xff1a;多年一线开发工作经验&#xff0c;原创团队&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取&#xff0c;记得注明来意哦~&#x1f339;赠送计算机毕业设计600个选题excel文…...

云盘系统设计

需求背景 网盘面向大量C端用户 1000w用户 DAU 20% 每天10次 QPS: 1000w * 0.2 * 10 / 100k 500 峰值估计&#xff1a;500 * 5 2500 功能需求 支持上传&#xff0c;下载&#xff0c;多端共同在线编辑&#xff0c;数据冲突处理 非功能需求 1.latency 20s左右 2.可用性与…...

西电雨课堂《知识产权法》课后作业答案

目录 第 1 章 1.1 课后作业 1.2 课后作业 第 2 章 2.1 课后作业 2.2 课后作业 2.3 课后作业 2.4 课后作业 2.5 课后作业 2.6 课后作业 2.7 课后作业 2.8 课后作业 2.9 课后作业 2.10 课后作业 第 3 章 3.1 课后作业 3.2 课后作业 3.3 课后作业 3…...

通信协议记录仪-产品规格书

以下是为 ​​通信协议记录仪(ProtoLogger Pro)​​ 的​​详细产品规格书​​,覆盖 ​​技术细节、场景需求、竞品差异化​​,确保可作为产品开发、市场营销及竞品分析的核心依据。 ​​通信协议记录仪产品规格书​​ ​​产品名称​​:ProtoLogger Pro(中文名称:蹲守…...

订单系统冷热分离方案:优化性能与降低存储成本

随着时间推移&#xff0c;订单数据不断积累。在电商平台或者服务型应用中&#xff0c;订单数据是核心数据之一。然而&#xff0c;随着数据量的增长&#xff0c;如何高效存储、管理和查询这些数据成为了系统架构设计的重要问题。在大多数情况下&#xff0c;订单数据的处理不仅涉…...

数据结构学习笔记

第 1 章 绪论 【考纲内容】 &#xff08;一&#xff09;数据结构的基本概念 &#xff08;二&#xff09;算法的基本概念 算法的时间复杂度和空间复杂度 【知识框架】 【复习提示】 本章内容是数据结构概述&#xff0c;并不在考研大纲中。读者可通过对本章的学习&#xff0c;初步…...

读懂 Vue3 路由:从入门到实战

在构建现代化单页应用&#xff08;SPA&#xff09;时&#xff0c;Vue3 凭借其简洁高效的特性成为众多开发者的首选。 而 Vue3 路由&#xff08;Vue Router&#xff09;则是 Vue3 生态中不可或缺的一部分&#xff0c;它就像是单页应用的 “导航地图”&#xff0c;帮助用户在不同…...

Aws S3上传优化

上传大约 3.4GB 的 JSON 文件&#xff0c;zip算法压缩后约为 395MB&#xff0c;上传至 S3 效率优化&#xff0c;有一些优化方案可以提高上传速率。下面是几种可能的优化方式&#xff0c;包括选择压缩算法、调整上传方式、以及其他可能的方案。 方案 1. 选择更好的压缩算法 压…...

Python 数据智能实战 (8):基于LLM的个性化营销文案

写在前面 —— 告别群发轰炸,拥抱精准沟通:用 LLM 为你的用户量身定制营销信息 在前面的篇章中,我们学习了如何利用 LLM 增强用户理解(智能分群)、挖掘商品关联(语义购物篮)、提升预测精度(融合文本特征的流失预警)。我们不断地从数据中提取更深层次的洞察。 然而,…...

html:table表格

表格代码示例&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title> </head> <body><!-- 标准表格。 --><table border"5"cellspacing&qu…...

2.maven 手动安装 jar包

1.背景 有的时候&#xff0c;maven仓库无法下载&#xff0c;可以手动安装。本文以pentaho-aggdesigner-algorithm-5.1.5-jhyde.jar为例。 2.预先准备 下载文件到本地指定位置。 2.1.安装pom mvn install:install-file \-Dfile/home/wind/tmp/pentaho-aggdesigner-5.1.5-jh…...

C++ unordered_set unordered_map

上篇文章我们讲解了哈希表的实现&#xff0c;这节尝试使用哈希表来封装unordered_set/map 1. unordered_set/map的框架 封装的过程实际上与set/map类似&#xff0c;在unordered_set/map层传递一个仿函数&#xff0c;用于取出key值 由于我们平常使用的都是unordered_set/map&…...

第37课 绘制原理图——放置离页连接符

什么是离页连接符&#xff1f; 前边我们介绍了网络标签&#xff08;Net Lable&#xff09;&#xff0c;可以让两根导线“隔空相连”&#xff0c;使原理图更加清爽简洁。 但是网络标签的使用也具有一定的局限性&#xff0c;对于两张不同Sheet上的导线&#xff0c;网络标签就不…...

< 自用文 Texas style Smoker > 美式德克萨斯烟熏炉 从设计到实现 (第一部分:烹饪室与燃烧室)

原因&#xff1a; 没钱还馋&#xff01; 但有手艺。 预计目标&#xff1a; 常见的两种偏置式烟熏炉&#xff08;Offset Smoker&#xff09; 左边边是标准偏置式&#xff08;Standard Offset&#xff09;&#xff0c;右边是反向流动式&#xff08;Reverse Flow Offset&#x…...

【现代深度学习技术】现代循环神经网络03:深度循环神经网络

【作者主页】Francek Chen 【专栏介绍】 ⌈ ⌈ ⌈PyTorch深度学习 ⌋ ⌋ ⌋ 深度学习 (DL, Deep Learning) 特指基于深层神经网络模型和方法的机器学习。它是在统计机器学习、人工神经网络等算法模型基础上&#xff0c;结合当代大数据和大算力的发展而发展出来的。深度学习最重…...

AimRT从入门到精通 - 03Channel发布者和订阅者

刚接触AimRT的小伙伴可能会疑惑&#xff0c;这个Channel和RPC&#xff08;后面讲的&#xff09;到底是什么呢&#xff1f; 但是当我们接触了之后&#xff0c;就会发现&#xff0c;其本质类似ROS的Topic通信&#xff01;&#xff08;其本质基于发布订阅模型&#xff09; 接下来…...

MySQL初阶:数据库基础,数据库和表操作,数据库中的数据类型

1.数据库基础 数据库是一个客户端——服务器结构的程序。 服务器是真正的主体&#xff0c;负责保存和管理数据&#xff0c;数据都存储在硬盘上 数据库处理的主要内容是数据的存储&#xff0c;查找&#xff0c;修改&#xff0c;排序&#xff0c;统计等。 关系型数据库&#…...

AI 驱动的智能交通系统:从拥堵到流畅的未来出行

最近研学过程中发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击链接跳转到网站人工智能及编程语言学习教程。读者们可以通过里面的文章详细了解一下人工智能及其编程等教程和学习方法。下面开始对正文内容的…...

Python清空Word段落样式的方法

在 Python 中&#xff0c;你可以使用 python-docx 库来操作 Word 文档&#xff0c;包括清空段落样式。以下是几种清空段落样式的方法&#xff1a; 方法一&#xff1a;直接设置段落样式为"Normal" from docx import Documentdoc Document(your_document.docx) # 打…...

[javaEE]网络编程

目录 socket对tcp ServerSocket ServerSocket 构造方法&#xff1a; ServerSocket 方法&#xff1a; socket 实现回显服务器和客户端 由于我们之前已经写多了socket对udq的实现&#xff0c;所以我们这节&#xff0c;主要将重心放在Tcp之上 socket对tcp ServerS…...

组件通信-mitt

mitt&#xff1a;与消息订阅与发布&#xff08;pubsub&#xff09;功能类似&#xff0c;可以实现任意组件间通信。 第一步&#xff1a;安装mitt npm i mitt 第二步&#xff1a;新建文件&#xff1a;src\utils\emitter.ts // 引入mitt import mitt from "mitt"; //调…...

微软发布了最新的开源推理模型套件“Phi-4-Reasoning

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…...