最新资讯

  • 2024最新鸿蒙开发面试题合集(一)-HarmonyOS NEXT Release(API 12 Release)

2024最新鸿蒙开发面试题合集(一)-HarmonyOS NEXT Release(API 12 Release)

2025-04-27 06:01:14 0 阅读

1. HarmonyOS应用打包后的文件扩展名是?

打包后的文件扩展名为.hapHarmonyOS Ability Package),这是HarmonyOS应用的标准包格式

2. 页面自定义组件生命周期有哪些?

页面和自定义组件生命周期说明

@Entry装饰器的@component组件的生命周期

  • onPageShow:页面每次显示时触发一次,包括路由过程、应用进入前台等场景。
  • onPageHide:页面每次隐藏时触发一次,包括路由过程、应用进入后台等场景。
  • onBackPress:当用户点击返回按钮时触发。

有@Entry装饰器和无@Entry装饰器@Component组件都有的生命周期

  • aboutToAppear:组件即将出现时回调该接口,具体时机为在创建自定义组件的新实例后,在执行其 build()函数之前执行。
  • onDidBuild:API12新增,组件 build()函数执行完成之后回调该接口,不建议在 onDidBuild函数中更改状态变量、使用 animateTo等功能,这会导致不稳定的UI表现
  • aboutToDisappear:aboutToDisappear函数在自定义组件析构销毁之前执行。不允许在aboutToDisappear函数中改变状态变量,特别是@Link变量的修改会导致应用程序行为不稳定。

3. 如何进行数据持久化?

应用数据持久化

  1. 用户首选项(Preferences):这是一种轻量级的配置数据持久化方式,适用于保存应用配置信息、用户偏好设置等。它通过文本形式保存数据,并且数据会全量加载到内存中,因此访问速度快,但不适合存储大量数据
  2. 键值型数据库(KV-Store):适用于存储结构简单的数据,如商品名称和价格、员工工号和出勤状态等。键值型数据库以“键值对”的形式组织数据,适合数据关系不复杂的场景。
  3. 关系型数据库(RelationalStore):基于SQLite,适用于存储包含复杂关系的数据,如学生信息、雇员信息等。关系型数据库提供了一系列SQL操作,如增删改查等。

4. 如何进行全局状态管理?

应用全局的UI状态存储

1. @Provide+@Consume装饰器

  • 适用场景:适用于整个组件树而言“全局”的状态共享,且该状态改动不频繁的场景。
  • 工作原理:通过在最顶层组件中使用 @Provide装饰器提供状态,其他需要共享状态的组件通过 @Consume装饰器获取该状态 。
  • 优点:减少了状态传递的层级,提升了代码的可维护性和可拓展性。
  • 注意事项:确保状态的生命周期与组件树的生命周期一致,避免不必要的UI刷新。

2. AppStorage

  • 适用场景:适用于整个应用而言“全局”的变量或应用的主线程内多个 UIAbility实例间的状态共享。
  • 工作原理:AppStorage与应用的进程绑定,由UI框架在应用程序启动时创建,当应用进程终止,AppStorage被回收。
  • 优点:适用于需要在整个应用中共享状态的场景。
  • 注意事项:确保状态的生命周期与应用进程一致,避免在应用退出后仍有状态存在。

3. LocalStorage

  • 适用场景:适用于单个Ability而言“全局”的变量,主要用于不同页面间的状态共享。
  • 工作原理:LocalStorage的生命周期由应用程序决定,当应用释放最后一个指向 LocalStorage的引用时,LocalStorage被垃圾回收。
  • 优点:适用于需要在单个UIAbility中不同页面间共享状态的场景。
  • 注意事项:确保状态的生命周期与应用程序的生命周期一致,避免在应用退出后仍有状态存在。


5. LocalStorage在应用重启后数据会消失吗?

页面级UI状态存储

因为LocalStorage 是一种用于页面或组件级别的数据存储方式,它允许开发者在页面或组件的生命周期内存储和检索数据。LocalStorage 的数据存储在内存中,因此它的读写速度相对较快。但是,当应用重启后,LocalStorage 中的数据会丢失。

6. 父子组件如何通信?

 
@Prop装饰器、@Link装饰器、@Provide和@Consume装饰器、@Event装饰器、@Parame装饰器、@Provider装饰器和@Consumer装饰器

当前(API 12)状态管理有两个版本 @Component@ComponentV2

1. 父子单向数据传递 @State+@Prop
@Prop装饰的变量可以和父组件建立单向的同步关系。@Prop装饰的变量是可变的,但是变化不会同步回其父组件。
2. 父子双向数据传递 @State+@Link@objectLink+@Link
子组件中被 @Link装饰的变量与其父组件中对应的数据源建立双向数据绑定。
3. 跨组件通信 @Provide装饰器和 @Consume装饰器
@Provide@Consume,应用于与后代组件的双向数据同步,应用于状态数据在多个层级之间传递的场景。不同于 @Prop和 @Link,@Provide和 @Consume摆脱参数传递机制的束缚,实现跨层级传递。
4. @Observed装饰器和 @ObjectLink装饰器
对于多层嵌套的情况,比如二维数组,或者数组项class,或者class的属性是class,他们的第二层的属性变化是无法观察到的。这就要用到 @Observed/@ObjectLink装饰器

注意:@ObjectLink装饰器不能在 @Entry装饰的自定义组件中使用且 @ObjectLink 装饰的变量不能被赋值,只能对其属性进行赋值操作


7. 兄弟组件如何通信?

1. 通过公共父组件传递

如果两个组件是同一个父组件的子组件,可以通过父组件来传递数据或事件。父组件可以作为中介,将一个子组件的数据或事件传递给另一个子组件。

2. 使用全局状态管理

使用全局状态管理(如 AppStorage、LocalStorage)来存储共享数据。兄弟组件可以独立地读取和更新这个全局状态,从而实现通信。

8. 如何实现页面间的通信?

1.使用 @Provide和 @Consume装饰器(见6.3)

2.使用路由跳转传参

import { router } from '@kit.ArkUI';
router.pushUrl({
  url: 'pages/Detail', // 目标url
   params: paramsInfo // 添加params属性,传递自定义参数
 })
 // 返回指定页面并携带参数
 router.back({
  url: 'pages/Home',
  params: {
    info: '来自Home页'
  }
});

3.使用导航跳转传参

this.pageStack.pushPath({ name: "PageOne", param: "PageOne Param" })
this.pageStack.pushPathByName("PageOne", "PageOne Param")

9. Navigation组件跳转和router跳转有什么区别?


官方文档写了很多,捡几个我觉得比较重要的写的

  1. Navigation:是路由容器组件,适用于模块内和跨模块的路由切换,一次开发,多端部署场景。Router位于页面栈管理节点 stage 下面,不提供导航容器的概念。
  2. NavigationRouter都支持跳转传参,但 Router对象中暂不支持方法变量。
  3. Navigation:支持清理指定路由,页面栈没有上限,可以无限跳转。Router不支持清理指定路由且页面栈最大为32,页面栈到达32之后必须清除之后才能继续跳转。
  4. Navigation:支持自定义转场动画和共享元素转场动画。 Router:仅支持简单自定义转场动画。
  5. Navigation:支持通过 setInterception 方法设置路由拦截。Router:不支持路由拦截。
  6. Navigation:支持沉浸式页面和模态嵌套路由。Router:不支持,需要通过窗口配置实现沉浸式页面。

总而言之,Navigation 组件在功能上更具丰富性和灵活性,特别是在处理复杂的导航结构、动效和路由管理方面。
Router 则提供了更基础的路由跳转功能,适合简单的路由需求。开发者可以根据应用的具体需求和设计选择最合适的路由方案。

具体的区别如下表:

10. HarmonyOS与Android和iOS有什么区别?


HarmonyOS 是华为开发的一个开源、分布式的操作系统。它设计用于多种设备,包括智能手机、平板电脑、智能电视和物联网设备。与Android和iOS的主要区别在于:

  • 分布式架构:HarmonyOS支持跨设备无缝协作,允许设备之间共享硬件资源。
  • 性能:HarmonyOS优化了任务调度和内存管理,提高了性能和响应速度
  • 安全性:HarmonyOS采用了多层次的安全策略,包括数据加密和安全启动。
  • 生态系统:HarmonyOS正在构建自己的应用生态系统,鼓励开发者使用Ark Ts和ArkUI框架。


11. 什么是Ability?


Ability是应用/服务所具备的能力的抽象,一个Module可以包含一个或多个 Ability ,在鸿蒙系统中,Ability提供了对 Ability生命周期、上下文环境等调用管理的能力,包括 Ability创建、销毁、转储客户端信息等

鸿蒙系统中的 Ability主要分为两种类型:UIAbility和 ExtensionAbility

1. UIAbility :

  • 定义 :包含UI界面,提供展示UI的能力,主要用于和用户交互 。
  • 创建 :在模块中添加UIAbility时,选中对应的模块,单击鼠标右键,选择New > Ability,设置Ability名称,选择是否在设备主屏幕上显示该功能的启动图标,单击Finish完成Ability创建 。

2. ExtensionAbility :

  • 定义 :提供特定场景的扩展能力,满足更多的使用场景 。
  • 创建 :在模块中添加ExtensionAbility时,选中对应的模块,单击鼠标右键,选择不同的场景类型(如Accessibility、EmbeddedUIExtensionAbility等) 。当前仅Application工程支持创建ExtensionAbility。设置Ability名称,单击Finish完成ExtensionAbility创建。


此外,Ability是Ability模块的基类,提供系统配置更新回调和系统内存调整回调 。Ability的继承关系包括UIAbility和ExtensionAbility等具体类.

总之,Ability是鸿蒙系统中用于管理应用能力的核心组件,通过不同类型的Ability可以实现不同的功能需求。

12. ArkUI框架有哪些特点?

ArkUI框架是鸿蒙(HarmonyOS)中的一个重要组件框架,具有以下几个特点:

  1. 组件树结构 : ArkUI框架通过布局组件和基础组件构建界面描述树(组件树),其中基础组件为叶子节点,布局组件为中间节点 。当用户进行交互时,会触发界面修改,通过重新渲染组件树来实现应用界面更新 。
  2. 数据与UI更新过程 : ArkUI框架的数据处理过程和UI更新过程是分开进行的。数据处理过程中,主要是对状态数据进行更新,并通过标脏过程确定布局最小影响范围,减少不必要的重新布局 。UI更新过程包括组件标脏、布局、测量和渲染等阶段 。
  3. 布局组件 : ArkUI框架提供了多种布局组件,如Row、Column、Stack、Flex、List、Grid、RelativeContainer等。开发者可以根据场景选择合适的布局组件,以优化性能 。例如,线性布局(Row、Column)适用于横向或纵向排列组件,而弹性布局(Flex)适用于需要弹性排列的场景。
  4. 性能优化 : ArkUI框架在性能优化方面做了很多工作。例如,通过减少不必要的组件嵌套和节点数量,降低布局测算的复杂度,从而提升性能。开发者可以使用DevEco Studio提供的工具(如Profiler和ArkUI Inspector)来查看性能瓶颈和组件树结构,进一步优化应用性能。
  5. 状态管理 : ArkUI框架支持状态管理最佳实践,通过有效的状态管理减少无效的UI更新操作,提升性能。例如,在状态变量变化导致UI更新时,只更新部分组件,而不是重新渲染整个界面。

13. 跨设备通信的方式有哪些?

HarmonyOS支持多种跨设备通信方式,包括:

  • 分布式软总线:一种高性能的通信机制,允许设备之间建立直接连接,进行数据传输。
  • 蓝牙:使用标准的蓝牙技术进行设备间的通信。
  • WLAN:通过WLAN网络实现设备间的通信。
  • 远程服务调用:通过分布式任务调度实现跨设备的服务调用。

14. 如何实现应用的后台运行?

  • 后台服务:使用后台服务(如BackgroundService)来执行不需要用户直接交互的任务。
  • 定时任务:通过系统提供的定时任务机制(如AlarmService)来周期性执行后台任务。
  • 事件监听:注册系统事件,如网络变化、电量变化等,以在特定事件发生时唤醒应用进行处理。

15. Ability是如何与用户交互的?

  • 界面显示:Ability可以包含一个或多个AbilitySlice,用于显示UI界面并与用户进行交互。
  • 事件处理:Ability可以处理用户的输入事件,如触摸、按键等。
  • 数据绑定:Ability可以使用数据绑定机制,将UI组件与数据模型绑定,实现数据的自动更新和交互。
  • 通知:Ability可以通过系统通知机制向用户发送通知,即使应用不在前台运行。

16. 如何实现应用的多语言支持?

  • 资源文件:为每种语言创建资源文件(如string.json),并在里面定义所有可本地化的字符串。
  • 资源引用:在代码中使用资源ID引用字符串,而不是硬编码文本。
  • 系统设置:应用会自动根据系统设置的语言环境加载相应的资源文件。
  • 动态切换:支持在应用运行时切换语言,并动态更新UI。

17. 分布式数据库是如何实现数据同步的?

  • 分布式事务:确保跨设备的数据库操作具有原子性、一致性、隔离性和持久性。
  • 数据版本控制:为数据添加版本号,确保同步时数据的一致性。
  • 冲突解决策略:定义冲突解决策略,处理并发操作导致的数据冲突。
  • 网络状态感知:根据网络状态智能同步数据,优化同步效率和流量使用。

18. 如何优化应用的性能?

  • 内存管理:合理分配和释放内存,避免内存泄漏。
  • 后台优化:合理使用后台服务和定时任务,避免不必要的后台运行。
  • UI渲染优化:使用轻量级的UI组件,减少布局复杂度,优化渲染性能。
  • 资源优化:压缩图片和媒体资源,减少应用的体积和加载时间。

19. HarmonyOS中的权限管理模型是怎样的?

  • 权限声明:应用在config.json中声明所需的权限。
  • 权限申请:在应用运行时,根据需要动态申请权限。
  • 权限检查:在执行敏感操作前,检查是否已获得相应权限。
  • 权限分组:系统将权限分为不同的组,便于管理和申请。

20. LazyForEach是什么?

LazyForEach 是一个用于高效渲染列表的组件或功能,它允许开发者在用户滚动列表时才加载和渲染列表项,而不是一次性渲染整个列表。这种按需渲染的方式可以显著提高应用的性能,特别是在处理大量数据时。

21. LazyForEach的工作原理是什么?

LazyForEach 的工作原理通常是基于用户的滚动位置来动态地创建和销毁列表项的组件实例。当用户滚动到列表的某个部分时,LazyForEach 会加载并渲染那些即将进入视图的列表项,同时可能会卸载那些滚出视图的列表项,以节省内存和计算资源。

22. Router.replace()方法的作用是什么?和Router.pushUrl()方法有什么区别?

Router.replace()方法用于替换当前路由,并将目标路由压入栈顶。与Router.pushUrl()方法不同,Router.replace()方法不会保留当前路由,而是直接替换掉当前路由。

23. 如何实现应用的沉浸式模式?

沉浸式模式是指应用界面呈现出沉浸式的全屏模式,不留任何系统UI,用户只能看到应用内容。在沉浸式模式下,应用的UI元素会被覆盖,但系统状态栏、导航栏、键盘等系统UI依然可见。以下是实现步骤

1. 设置窗口属性:
在应用的入口Ability中,可以通过设置窗口属性来实现沉浸式模式。这通常涉及到配置窗口特性(Window Features)来隐藏状态栏和导航栏。
2. 使用系统API:
鸿蒙OS提供了API来控制系统UI的显示和隐藏。你可以在应用的代码中调用这些API来实现沉浸式效果。
3. 配置应用的配置文件:
在应用的config.json或其他配置文件中,可以声明应用需要的窗口特性,如ohos:immersive。
4. 动态切换:
应用可以根据用户的交互或特定场景动态地进入或退出沉浸式模式。这可能涉及到监听用户的手势或其他事件来切换UI状态。
5. 适配不同设备:
不同的设备可能有不同的屏幕和系统UI,因此在实现沉浸式模式时,需要考虑不同设备的适配问题。


24. 如何获取屏幕的安全区域?

  1. 可以通过设置组件的expandSafeArea属性来获取获取UIWindow:首先,你需要获取到当前页面的UIWindow实例。
  2. 调用getSafeArea方法:通过UIWindow实例调用getSafeArea方法来获取安全区域的Rect对象。

示例:

import ohos.aafwk.ability.AbilitySlice;
import ohos.aafwk.content.Intent;
import ohos.agp.window.UIWindow;
import ohos.agp.utils.Rect;
public class MyAbilitySlice extends AbilitySlice {
    @Override
    public void onStart(Intent intent) {
        super.onStart(intent);
        setUIContent(new SurfaceLayout(this));
        UIWindow window = getUIWindow();
        if (window != null) {
            // 获取安全区域
            Rect safeArea = window.getSafeArea();
            // 在这里可以使用safeArea对象,它包含了安全区域的位置和尺寸信息
            // 例如,可以使用safeArea.left, safeArea.top, safeArea.right, safeArea.bottom
        }
    }
}

25. ArkTs是什么?

ArkTs介绍

ArkTS是HarmonyOS优选的主力应用开发语言。保持了TypeScript的基本风格,同时通过规范定义强化开发期静态检查和分析,提升程序执行稳定性性能


ArkTS的主要特点包括:

  • 静态类型检查:ArkTS在编译时进行类型检查,这有助于在代码运行前发现和修复错误,提高代码的稳定性和性能。
  • 声明式UI:ArkTS定义了声明式UI描述,允许开发者以更简洁、更自然的方式开发跨端应用。
  • 状态管理:ArkTS提供了多维度的状态管理机制,使得与UI相关联的数据可以在组件内使用,也可以在不同组件层级间传递,支持单向和双向数据流。
  • 渲染控制:ArkTS支持条件渲染、循环渲染和数据懒加载,允许开发者根据应用的不同状态渲染UI内容。
  • 兼容性:ArkTS兼容TS/JavaScript生态,开发者可以使用TS/JS进行开发或复用已有代码。
  • 并发机制:ArkTS支持轻量化的并发机制,允许开发者编写并发代码,提高应用的性能和响应速度。


26. ArkTs与TypeScript有什么区别?(答5点以上)

ArkTs官方文档

ArkTS 是基于 TypeScript 开发的框架,但是有一些限制和差异。ArkTS 旨在提供更严格的类型检查和优化的代码性能,同时确保与 HarmonyOS 的开发环境和特性兼容。以下是 ArkTS 与 TypeScript 的差异:

  • 不支持使用对象字面量声明类型。
  • 不支持使用 var关键字。
  • 不支持使用 in运算符。
  • 不支持导入断言。
  • 不支持使用 any类型。
  • 不支持使用 import赋值表达式。
  • 不支持使用 require导入


具体区别:

  1. 生成器函数:ArkTS 不支持 TypeScript 中的生成器函数(使用 function* 定义的函数),应使用 async await 机制进行并行任务处理 。
  2. 参数解构:在函数参数中使用解构赋值是 TypeScript 的特性,ArkTS 不支持参数解构,需要显式传递参数 。
  3. 函数内声明函数:TypeScript 允许在函数内部声明新的函数,而 ArkTS 不支持在函数内声明函数,应使用 lambda 函数代替 。
  4. new.target:ArkTS 不支持 new.target 元属性,这是 TypeScript 中用于反射的属性 。
  5. 确定赋值断言:TypeScript 中的 ! 确定赋值断言在 ArkTS 中不被支持,应初始化变量或使用其他方式确保赋值 。
  6. 原型上的赋值:ArkTS 不支持在对象的原型上进行赋值,这与 TypeScript 不同 。
  7. globalThis:ArkTS 不支持 globalThis,这是 TypeScript 中用于获取全局对象的属性 。
  8. Function.prototype.applyFunction.prototype.callFunction.prototype.bind:ArkTS 不支持这些函数,它们在 TypeScript 中用于控制函数的 this 绑定 。
  9. instanceof as 类型保护:ArkTS 不支持 is 运算符,必须使用 instanceof 运算符替代,并且在使用之前,必须使用 as 运算符将对象转换为需要的类型 。
  10. 接口继承类:在 TypeScript 中,接口可以继承类,但在 ArkTS 中,接口只能继承接口 。
  11. 构造函数类型:ArkTS 不支持使用构造函数类型,应改用 lambda 函数 。
  12. enum 声明合并:ArkTS 不支持 enum 声明合并,所有相关的枚举成员必须在同一个声明中 。
  13. 命名空间作为对象:ArkTS 不支持将命名空间用作对象,可以使用类或模块替代 。
  14. 非声明语句在命名空间中:ArkTS 中,命名空间用于定义标志符可见范围,不支持命名空间中的非声明语句 。
  15. import default as ...:ArkTS 不支持 import default as ... 语法,应使用显式的 import ... from ... 语法 。
  16. require import 赋值表达式:ArkTS 不支持通过 require 导入,也不支持 import 赋值表达式,应使用 import 语法 。
  17. ambient 模块声明:ArkTS 不支持 declare module 语法,应直接导入需要的内容 。
  18. new.target:ArkTS 不支持 new.target 元属性,这是 TypeScript 中用于反射的属性 。
  19. Function.prototype.apply、Function.prototype.call 和 Function.prototype.bind:ArkTS 不支持这些函数,它们在 TypeScript 中用于控制函数的 this 绑定 。
  20. as const 断言:ArkTS 不支持 as const 断言,这是 TypeScript 中用于标注字面量的相应字面量类型的语法 。
  21. any:ArkTS 不支持any类型, 应使用更具体的类型替代 。

27. @Provider和@Consumer vs @Provide和@Consume的区别?

@Provider和@Consumer 官方文档

28. @Prop和@ObjectLink装饰器有什么区别?

1.用途

  • @Prop装饰器:主要用于在组件之间传递数据,将父组件的值传递给子组件。它定义了子组件的属性,可以接收来自父组件的赋值。@ObjectLink用于建立对象之间的链接,通常用于在组件内部或组件之间共享和同步状态。它可以将一个对象的属性与另一个对象的属性进行链接,当一个对象的属性发生变化时,另一个对象的属性也会自动更新。

2. 数据传递方式

  • @Prop:是单向的数据传递,从父组件到子组件。父组件可以设置子组件的 @Prop属性值,但子组件不能直接修改这个值。@ObjectLink是双向的数据传递,父组件和子组件都可以修改子组件的 @ObjectLink属性值。

3. 性能

  • @Prop会深拷贝数据,具有拷贝的性能开销,性能低于 @ObjectLink详见官方文档。

29. ForEach和LazyForEach的区别?

ForEach和LazyForEach都是用于渲染列表的装饰器,它们的区别在于:

  • ForEach:渲染列表时,会将列表中的每一项都渲染一次,适用于列表项数量较少的情况。
  • LazyForEach:渲染列表时,只渲染当前可见的列表项,适用于列表项数量较多的情况。

30. UIAbility的生命周期有哪些?

官方文档说明

UIAbility的生命周期包括CreateForegroundBackgroundDestroy四个状态

31. H5如何与HarmonyOS应用(webView)进行通信?官方文档

  • 应用侧调用前端页面JS函数

应用侧可以通过runJavaScript()方法异步调用前端页面的JavaScript相关函数,并通过Promise方式返回脚本执行的结果。runJavaScript需要在loadUrl完成后,比如onPageEnd中调用。

  • 前端页面调用应用侧函数

使用Web组件将应用侧代码注册到前端页面中,注册完成之后,前端页面中使用注册的对象名称就可以调用应用侧的函数,实现在前端页面中调用应用侧方法。注册应用侧代码有两种方式,一种在Web组件初始化调用,使用javaScriptProxy()接口。另外一种在Web组件初始化完成后调用,使用registerJavaScriptProxy()接口。

32. 如何实现图片上传?

有两种方式原生和Web组件:

  • 原生:使用上传下载模块(ohos.request)的上传接口将本地文件(图片)上传,需声明权限:ohos.permission.INTERNET

代码示例:

// pages/xxx.ets
import { common } from '@kit.AbilityKit';
import fs from '@ohos.file.fs';
import { BusinessError, request } from '@kit.BasicServicesKit';

// 获取应用文件路径
let context = getContext(this) as common.UIAbilityContext;
let cacheDir = context.cacheDir;

// 新建一个本地应用文件
let file = fs.openSync(cacheDir + '/test.txt', fs.OpenMode.READ_WRITE | fs.OpenMode.CREATE);
fs.writeSync(file.fd, 'upload file test');
fs.closeSync(file);

// 上传任务配置项
let header = new Map();
header.set('key1', 'value1');
header.set('key2', 'value2');
let files: Array = [
//uri前缀internal://cache 对应cacheDir目录
  { filename: 'test.txt', name: 'test', uri: 'internal://cache/test.txt', type: 'txt' }
]
let data: Array = [{ name: 'name', value: 'value' }];
let uploadConfig: request.UploadConfig = {
  url: 'https://xxx',
  header: header,
  method: 'POST',
  files: files,
  data: data
}

// 将本地应用文件上传至网络服务器
try {
  request.uploadFile(context, uploadConfig)
    .then((uploadTask: request.UploadTask) => {
      uploadTask.on('complete', (taskStates: Array) => {
        for (let i = 0; i < taskStates.length; i++) {
          console.info(`upload complete taskState: ${JSON.stringify(taskStates[i])}`);
        }
      });
    })
    .catch((err: BusinessError) => {
      console.error(`Invoke uploadFile failed, code is ${err.code}, message is ${err.message}`);
    })
} catch (error) {
  let err: BusinessError = error as BusinessError;
  console.error(`Invoke uploadFile failed, code is ${err.code}, message is ${err.message}`);
}
  • 使用axios上传:使用axios上传文件,需安装axios依赖。

注意事项

  1. 上传文件需要单独导入FormData模块
  2. 当前版本只支持 Stage 模型
  3. 上传类型支持uri和ArrayBuffer,uri支持“internal”协议类型和沙箱路径,仅支持"internal"协议类型,"internal://cache/"为必填字段,示例: internal://cache/path/to/file.txt;沙箱路径示例:cacheDir + ‘/hello.txt’
  4. 请求的表单数据值为string类型
  5. 支持设置多部分表单数据的数据名称和数据类型类型
  6. 上传参数context:当uri为沙箱路径,无需传参context;若uri为“internal”协议类型,必须传参context

当上传的内容为ArrayBuffer时,用法如下

import axios from '@ohos/axios'
import { FormData } from '@ohos/axios'
import fs from '@ohos.file.fs';

// ArrayBuffer
let formData = new FormData()
let cacheDir = getContext(this).cacheDir
try {
  // 写入
  let path = cacheDir + '/hello.txt';
  let file = fs.openSync(path, fs.OpenMode.CREATE | fs.OpenMode.READ_WRITE)
  fs.writeSync(file.fd, "hello, world"); // 以同步方法将数据写入文件
  fs.fsyncSync(file.fd); // 以同步方法同步文件数据。
  fs.closeSync(file.fd);

  // 读取
  let file2 = fs.openSync(path, 0o2);
  let stat = fs.lstatSync(path);
  let buf2 = new ArrayBuffer(stat.size);
  fs.readSync(file2.fd, buf2); // 以同步方法从流文件读取数据。
  fs.fsyncSync(file2.fd);
  fs.closeSync(file2.fd);

  formData.append('file', buf2);
  // formData.append('file', buf2, { filename: 'text.txt', type: 'text/plain'}); 设置多部分表单数据的数据名称和数据类型类型
} catch (err) {
  console.info('err:' + JSON.stringify(err));
}
// 发送请求
axios.post, FormData>(this.uploadUrl, formData, {
  headers: { 'Content-Type': 'multipart/form-data' },
  context: getContext(this),
  onUploadProgress: (progressEvent: AxiosProgressEvent): void => {
  console.info(progressEvent && progressEvent.loaded && progressEvent.total ? Math.ceil(progressEvent.loaded / progressEvent.total * 100) + '%' : '0%');
},
}).then((res: AxiosResponse) => {
  console.info("result" + JSON.stringify(res.data));
}).catch((error: AxiosError) => {
  console.error("error:" + JSON.stringify(error));
})

当上传的uri时,用法如下

import axios from '@ohos/axios'
import { FormData } from '@ohos/axios'

let formData = new FormData()
formData.append('file', 'internal://cache/blue.jpg')
// formData.append('file', cacheDir + '/hello.txt'); uri支持传入沙箱路径

// 发送请求
axios.post, FormData>('https://www.xxx.com/upload', formData, {
  headers: { 'Content-Type': 'multipart/form-data' },
  context: getContext(this),
  onUploadProgress: (progressEvent: AxiosProgressEvent): void => {
    console.info(progressEvent && progressEvent.loaded && progressEvent.total ? Math.ceil(progressEvent.loaded / progressEvent.total * 100) + '%' : '0%');
  },
}).then((res: AxiosResponse) => {
  console.info("result" + JSON.stringify(res.data));
}).catch((err: AxiosError) => {
  console.error("error:" + JSON.stringify(err));
})

33.hap、har、hsp三者的区别?

  • HAP(Harmony Ability Package)应用安装和运行的基本单元。HAP包是由代码、资源、第三方库、配置文件等打包生成的模块包,其主要分为两种类型:entry和feature。(又称ability)
  • HAR(Harmony Archive)静态共享包,可以包含代码、C++库、资源和配置文件。通过HAR可以实现多个模块或多个工程共享ArkUI组件、资源等相关代码。(又称static library, 静态共享包)
  • HSP(Harmony Shared Package)动态共享包,可以包含代码、C++库、资源和配置文件,通过HSP可以实现代码和资源的共享。HSP不支持独立发布,而是跟随其宿主应用的APP包一起发布,与宿主应用同进程,具有相同的包名和生命周期。(又称shared library, 动态共享包)

34. 鸿蒙常用的装饰器有哪些?

  • @State 定义状态,当前组件能使用
  • @Prop 父子组件通信(特点:子组件数据不能修改)
  • @Link 父子组件通信(特点:子组件数据可以修改)
  • @Observed 和 @ObjectLink 父子组件通信(特点:嵌套第二层数据修改可以达到响应式,之前方案不行)
  • @Provide 和 @Consume 祖孙组件通信
  • @Builder 和 @BuilderParam 父子组件通信,通信组件数据
  • @Watch 监视数据的变化(第一次不会触发)

35. 如何启动一个 ability?

通过 context 对象的 startAbility 方法官方文档:


import { common, Want } from '@kit.AbilityKit';
import { BusinessError } from '@kit.BasicServicesKit';

context = getContext(this) as common.UIAbilityContext; // UIAbilityContext

const want: Want = {
  deviceId: '', // deviceId为空表示本设备
  bundleName: 'com.example.system', // AppScope/app.json5 中找
  abilityName: 'SecondAbility', // 去对应的ability内部找module.json5
  // moduleName: 'entry' // moduleName非必选
  parameters: { // 携带参数

  }
};
this.context.startAbility(want, (err: BusinessError) => {
  if (err.code) {
    // 显式拉起Ability,通过bundleName、abilityName和moduleName可以唯一确定一个Ability
    console.error(`Failed to startAbility. Code: ${err.code}, message: ${err.message}`);
  }
});

36. 显示 want 和 隐式 want 的区别?

官方文档

  • 显式Want:在启动目标应用组件时,调用方传入的want参数中指定了abilityName和bundleName,称为显式Want。显式Want通常用于应用内组件启动,通过在Want对象内指定本应用Bundle名称信息(bundleName)和abilityName来启动应用内目标组件。当有明确处理请求的对象时,显式Want是一种简单有效的启动目标应用组件的方式。例如:打开其他窗口
  • 隐式Want:在启动目标应用组件时,调用方传入的want参数中未指定abilityName,称为隐式Want。当需要处理的对象不明确时,可以使用隐式Want,在当前应用中使用其他应用提供的某个能力,而不关心提供该能力的具体应用。隐式Want使用skills标签来定义需要使用的能力,并由系统匹配声明支持该请求的所有应用来处理请求。例如,需要打开一个链接的请求,系统将匹配所有声明支持该请求的应用,然后让用户选择使用哪个应用打开链接。例如:将pdf文件传递给其他应用窗口

总的来说

  • 显示want和隐式want的区别在于有无abilityName。有就是显示want,没有就是隐式want
  • 显示want主要用于当前应用窗口跳转,隐式want打开其他应用的窗口


37. 三层架构是什么?

官方文档

三层架构为了“一次开发,多端部署”,项目结构采用三层架构
三层工程结构如下:

  • commons(公共能力层):用于存放公共基础能力集合(如工具库、公共配置等)。commons层可编译成一个或多个HAR包或HSP包,只可以被products和features依赖,不可以反向依赖。
  • features(基础特性层):开发页面、组件(HAR包或HSP包)。
  • products(产品定制层):定义phonepad两个ability,引用 features 的包和 commons 的包完成应用功能


38. 优化内存有哪些方法?

官方文档

1. 使用onMemoryLevel监听内存变化

2. 使用LRUCache优化ArkTS内存
例如:我们搜索租房列表可以无限加载租房数据,这样数据会越来越多,我们使用LRUCacheUtil来管理数据
3. 使用生命周期管理优化ArkTS内存
例如:aboutToDisappear中销毁订阅事件,清除定时器等
4.使用purgeable优化C++内存

39. 多线程实现方式TaskPoll和Worker的区别?

  1. TaskPool和Worker均支持多线程并发能力。由于TaskPool的工作线程会绑定系统的调度优先级,并且支持负载均衡(自动扩缩容),而Worker需要开发者自行创建,存在创建耗时以及不支持设置调度优先级,故在性能方面使用TaskPool会优于Worker,因此大多数场景推荐使用TaskPool。
  2. TaskPool偏向独立任务维度,该任务在线程中执行,无需关注线程的生命周期,超长任务(大于3分钟且非长时任务)会被系统自动回收;而Worker偏向线程的维度,支持长时间占据线程执行,需要主动管理线程生命周期。

40. 音视频的组件的使用方式?

  • 视频组件 Video
controller: VideoController = new VideoController()
Video({
  src: $rawfile('test.mp4'),
  previewUri: $r('app.media.startIcon'),
  controller: this.controller
})
.width('100%')
.height(200)
.autoPlay(true)
.controls(true)
  • 音频组件 Audio 官方文档(了解)
//配置音频渲染参数并创建AudioRenderer实例,音频渲染参数的详细信息可以查看AudioRendererOptions。
import { audio } from '@kit.AudioKit';
let audioStreamInfo: audio.AudioStreamInfo = {
  samplingRate: audio.AudioSamplingRate.SAMPLE_RATE_48000, // 采样率
  channels: audio.AudioChannel.CHANNEL_2, // 通道
  sampleFormat: audio.AudioSampleFormat.SAMPLE_FORMAT_S16LE, // 采样格式
  encodingType: audio.AudioEncodingType.ENCODING_TYPE_RAW // 编码格式
};
let audioRendererInfo: audio.AudioRendererInfo = {
  usage: audio.StreamUsage.STREAM_USAGE_VOICE_COMMUNICATION,
  rendererFlags: 0
};
let audioRendererOptions: audio.AudioRendererOptions = {
  streamInfo: audioStreamInfo,
  rendererInfo: audioRendererInfo
};
audio.createAudioRenderer(audioRendererOptions, (err, data) => {
  if (err) {
    console.error(`Invoke createAudioRenderer failed, code is ${err.code}, message is ${err.message}`);
    return;
  } else {
    console.info('Invoke createAudioRenderer succeeded.');
    let audioRenderer = data;
  }
});
// 调用on('writeData')方法,订阅监听音频数据写入回调。
import { BusinessError } from '@kit.BasicServicesKit';
import { fileIo } from '@kit.CoreFileKit';
let bufferSize: number = 0;
class Options {
  offset?: number;
  length?: number;
}
let path = getContext().cacheDir;
//确保该路径下存在该资源
let filePath = path + '/StarWars10s-2C-48000-4SW.wav';
let file: fileIo.File = fileIo.openSync(filePath, fileIo.OpenMode.READ_ONLY);
let writeDataCallback = (buffer: ArrayBuffer) => {
  let options: Options = {
    offset: bufferSize,
    length: buffer.byteLength
  }
  fileIo.readSync(file.fd, buffer, options);
  bufferSize += buffer.byteLength;
}
audioRenderer.on('writeData', writeDataCallback);
//调用start()方法进入running状态,开始渲染音频。
import { BusinessError } from '@kit.BasicServicesKit';
audioRenderer.start((err: BusinessError) => {
  if (err) {
    console.error(`Renderer start failed, code is ${err.code}, message is ${err.message}`);
  } else {
    console.info('Renderer start success.');
  }
});
//调用stop()方法停止渲染。
import { BusinessError } from '@kit.BasicServicesKit';
audioRenderer.stop((err: BusinessError) => {
  if (err) {
    console.error(`Renderer stop failed, code is ${err.code}, message is ${err.message}`);
  } else {
    console.info('Renderer stopped.');
  }
});
// 调用release()方法销毁实例,释放资源。
import { BusinessError } from '@kit.BasicServicesKit';
audioRenderer.release((err: BusinessError) => {
  if (err) {
    console.error(`Renderer release failed, code is ${err.code}, message is ${err.message}`);
  } else {
    console.info('Renderer released.');
  } 
});

本文地址:https://www.vps345.com/2935.html

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP 服务器 linux 运维 游戏 云计算 进程 操作系统 进程控制 Ubuntu ssh deepseek Ollama 模型联网 API CherryStudio python MCP 数据库 centos oracle 关系型 安全 分布式 llama 算法 opencv 自然语言处理 神经网络 语言模型 javascript 前端 chrome edge react.js 前端面试题 node.js 持续部署 Dell R750XS 科技 ai java 人工智能 个人开发 harmonyos 华为 开发语言 typescript 计算机网络 ubuntu numpy 阿里云 网络 网络安全 网络协议 adb nginx 监控 自动化运维 笔记 C 环境变量 进程地址空间 macos zotero WebDAV 同步失败 代理模式 IIS .net core Hosting Bundle .NET Framework vs2022 经验分享 ollama llm php android http ESP32 串口服务器 YOLO 深度学习 pytorch nuxt3 vue3 sql KingBase fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse 银河麒麟 kylin v10 麒麟 v10 spring boot websocket docker 实时音视频 filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 golang kubernetes 容器 学习方法 程序人生 gitlab c++ c语言 tcp/ip rust DeepSeek-R1 API接口 多线程服务器 Linux网络编程 json html5 firefox pycharm conda pillow spring django flask web3.py github 创意 社区 自动化 蓝耘科技 元生代平台工作流 ComfyUI RTSP xop RTP RTSPServer 推流 视频 kvm 无桌面 命令行 matlab ecm bpm 媒体 agi AIGC 计算机视觉 ansible playbook gpu算力 安装教程 GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 H3C Reactor 设计模式 性能优化 C++ uni-app udp unity redis 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 后端 华为云 物联网 springsecurity6 oauth2 授权服务器 前后端分离 prometheus 监控k8s集群 集群内prometheus 向日葵 架构 arm html FunASR ASR 佛山戴尔服务器维修 佛山三水服务器维修 android studio 交互 go file server http server web server windows 集成学习 集成测试 vscode 代码调试 ipdb 远程连接 rdp 实验 远程工作 ssl 消息队列 tomcat UOS 统信操作系统 yum 编辑器 oceanbase rc.local 开机自启 systemd 麒麟 面试 jdk intellij-idea 机器学习 kylin 深度优先 图论 并集查找 换根法 树上倍增 AI MNN DeepSeek Qwen 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 chatgpt 大模型 llama3 Chatglm 开源大模型 web安全 大数据 hugo microsoft arm开发 DeepSeek行业应用 Heroku 网站部署 xss AI编程 pppoe radius 医疗APP开发 app开发 AI agent vue.js audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 Docker Compose docker compose docker-compose java-ee react next.js 部署 部署next.js YOLOv8 NPU Atlas800 A300I pro TRAE 国标28181 视频监控 监控接入 语音广播 流程 SIP SDP 机器人 googlecloud bash 小程序 JAVA IDEA Java 弹性计算 虚拟化 KVM 计算虚拟化 弹性裸金属 idm ide Dify jenkins 云原生 ci/cd 学习 宝塔面板 同步 备份 建站 安全威胁分析 vscode 1.86 豆瓣 追剧助手 迅雷 nas 微信 内存 unity3d 目标检测 fpga开发 LDAP https jvm aws 服务器繁忙 备选 网站 api 调用 示例 银河麒麟桌面操作系统 Kylin OS 国产化 Agent postman mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 maven intellij idea 腾讯云 运维开发 报错 qt IIS服务器 IIS性能 日志监控 MQTT mosquitto 智能路由器 外网访问 内网穿透 端口映射 word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 spring cloud sqlite dubbo TCP服务器 qt项目 qt项目实战 qt教程 openssl 密码学 shell ios flutter 根服务器 debian kafka hibernate AI大模型 大模型入门 Deepseek 大模型教程 sqlserver Linux 国产操作系统 ukui 麒麟kylinos openeuler 微服务 统信 虚拟机安装 游戏程序 ffmpeg 音视频 excel git eureka mysql apache 孤岛惊魂4 恒源云 tcp oneapi open webui GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 mongodb 博客 权限 3d 数学建模 网络结构图 爬虫 Headless Linux 远程登录 telnet pdf asp.net大文件上传 asp.net大文件上传下载 asp.net大文件上传源码 ASP.NET断点续传 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 华为认证 网络工程师 交换机 开源 电脑 visualstudio k8s c# zookeeper virtualenv live555 rtsp rtp armbian u-boot 嵌入式硬件 驱动开发 硬件工程 嵌入式实习 WSL win11 无法解析服务器的名称或地址 ftp gitee Cline ecmascript nextjs reactjs Cursor URL 搜索引擎 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 MI300x openwrt Docker Hub docker pull 镜像源 daemon.json ux 多线程 vim LLM Web APP Streamlit 单片机 stm32 string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap 开发环境 SSL证书 Python 网络编程 聊天服务器 套接字 TCP 客户端 Socket 重启 排查 系统重启 日志 原因 pygame 小游戏 五子棋 svn 能力提升 面试宝典 技术 IT信息化 源码剖析 rtsp实现步骤 流媒体开发 odoo 服务器动作 Server action Flask FastAPI Waitress Gunicorn uWSGI Uvicorn 僵尸进程 银河麒麟操作系统 rpc 远程过程调用 Windows环境 直播推流 Linux PID 微信公众平台 C语言 ipython Hyper-V WinRM TrustedHosts 联想开天P90Z装win10 jmeter 软件测试 flash-attention asi_bench C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 统信UOS bonding 链路聚合 mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 MCP server C/S LLM windows日志 安全架构 游戏服务器 Minecraft ddos 数据集 cursor glibc npm 常用命令 文本命令 目录命令 低代码 thingsboard postgresql devops 负载均衡 unix LORA 大语言模型 NLP 1024程序员节 ardunio BLE 端口测试 onlyoffice iDRAC R720xd 命名管道 客户端与服务端通信 r语言 企业微信 Linux24.04 deepin freebsd AI写作 prompt HarmonyOS dell服务器 图形化界面 硬件架构 系统架构 iventoy VmWare OpenEuler css3 XFS xfs文件系统损坏 I_O error es 游戏引擎 抗锯齿 deepseek r1 cnn GoogLeNet 磁盘监控 iot cd 目录切换 jupyter zabbix make命令 makefile文件 系统安全 tensorflow openEuler 图像处理 elasticsearch 程序员 无人机 jar 服务器主板 AI芯片 信息与通信 iphone rclone AList webdav fnOS apt 国内源 安卓 ruoyi 前端框架 hadoop HarmonyOS Next wireshark 镜像 我的世界服务器搭建 asm selenium 测试工具 王者荣耀 Wi-Fi xpath定位元素 超融合 minio matplotlib Spring Security 我的世界 我的世界联机 数码 鸿蒙系统 uv 缓存 鸿蒙 华为od ISO镜像作为本地源 navicat 程序 群晖 云电竞 云电脑 todesk 文件系统 路径解析 视觉检测 proxy模式 ROS 自动驾驶 BMC IPMI 带外管理 职场和发展 db safari pip Mac 系统 微信小程序 虚拟局域网 jetty undertow 历史版本 下载 安装 tidb GLIBC nvidia less 智能手机 NAS Termux Samba 计算机外设 显卡驱动 rabbitmq ruby express Kali 虚拟机 信号处理 实习 MacOS录屏软件 Erlang OTP gen_server 热代码交换 事务语义 c mamba Vmamba tcpdump ip ui 远程桌面 gaussdb wordpress 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 实战案例 GPU ESXi 金仓数据库 2025 征文 数据库平替用金仓 ocr 思科模拟器 思科 Cisco IM即时通讯 QQ 剪切板对通 HTML FORMAT 虚幻 线程 云服务 fd 文件描述符 mac bcompare Beyond Compare 模拟器 教程 kind AI作画 聊天室 list 模拟实现 docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos cocoapods xcode KylinV10 麒麟操作系统 Vmware 其他 银河麒麟服务器操作系统 系统激活 threejs 3D springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 5G 3GPP 卫星通信 SenseVoice 算力 visual studio code nac 802.1 portal Radius P2P HDLC muduo Qwen2.5-coder 离线部署 QT 5.12.12 QT开发环境 Ubuntu18.04 个人博客 X11 Xming 双系统 GRUB引导 Linux技巧 技能大赛 iBMC UltraISO windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 wsl 课程设计 yolov8 EMQX 通信协议 GCC aarch64 编译安装 HPC HAProxy 数据库架构 数据管理 数据治理 数据编织 数据虚拟化 中兴光猫 换光猫 网络桥接 自己换光猫 Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 vue css Python基础 Python教程 Python技巧 wps grafana 直流充电桩 充电桩 junit ArkUI 多端开发 智慧分发 应用生态 鸿蒙OS SEO 漏洞 显示管理器 lightdm gdm ceph 树莓派 VNC 远程 命令 执行 sshpass 操作 阻塞队列 生产者消费者模型 服务器崩坏原因 laravel AnythingLLM AnythingLLM安装 rocketmq linux安装配置 Nuxt.js webrtc SSH Xterminal rnn 压力测试 netty dify 深度求索 私域 知识库 p2p 环境配置 Claude 单元测试 功能测试 网络穿透 云服务器 etcd 数据安全 RBAC frp 嵌入式 linux驱动开发 Netty 即时通信 NIO 腾讯云大模型知识引擎 HTTP 服务器控制 ESP32 DeepSeek seatunnel k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm 换源 Debian AD域 反向代理 致远OA OA服务器 服务器磁盘扩容 jina okhttp CORS 跨域 游戏机 rag ragflow ragflow 源码启动 crosstool-ng 技术共享 ue4 着色器 ue5 can 线程池 vasp安装 wsl2 查询数据库服务IP地址 SQL Server 加解密 Yakit yaklang 语音识别 AutoDL mariadb 开机自启动 HCIE 数通 cuda cudnn anaconda 模拟退火算法 selete 高级IO 多层架构 解耦 ssh远程登录 code-server SVN Server tortoise svn 数据挖掘 数据可视化 数据分析 SysBench 基准测试 linux上传下载 计算机 鲲鹏 昇腾 npu 健康医疗 互联网医院 eclipse gateway Clion Nova ResharperC++引擎 Centos7 远程开发 业界资讯 redhat kamailio sip VoIP 微信分享 Image wxopensdk 大数据平台 银河麒麟高级服务器 外接硬盘 Kylin 中间件 gradle Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 浏览器开发 AI浏览器 lio-sam SLAM AISphereButler Java Applet URL操作 服务器建立 Socket编程 网络文件读取 yaml Ultralytics 可视化 Dell HPE 联想 浪潮 rust腐蚀 信号 框架搭建 etl .net 回显服务器 UDP的API使用 HiCar CarLife+ CarPlay QT RK3588 vSphere vCenter Node-Red 编程工具 流编程 springboot 小艺 Pura X 升级 CVE-2024-7347 VPS Typore .net mvc断点续传 温湿度数据上传到服务器 Arduino HTTP 需求分析 规格说明书 bat web 服务器管理 配置教程 服务器安装 网站管理 雨云 NPS 飞书 数据结构 web3 linux 命令 sed 命令 autodl 软件定义数据中心 sddc 矩阵 big data VR手套 数据手套 动捕手套 动捕数据手套 Linux的基础指令 大模型微调 工业4.0 IMM rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK echarts IMX317 MIPI H265 VCU composer 交叉编译 传统数据库升级 银行 LLMs 单一职责原则 IPMITOOL 硬件管理 opcua opcda KEPServer安装 token sas 边缘计算 小智AI服务端 xiaozhi TTS FTP 服务器 7z gitea Linux环境 输入法 av1 电视盒子 机顶盒ROM 魔百盒刷机 hexo 移动云 可信计算技术 僵尸世界大战 游戏服务器搭建 编程 性能分析 nfs SSL 域名 rsyslog Anolis nginx安装 环境安装 linux插件下载 v10 软件 毕昇JDK webstorm Trae IDE AI 原生集成开发环境 Trae AI 策略模式 单例模式 mcu 实时互动 SWAT 配置文件 服务管理 网络共享 CPU 主板 电源 网卡 项目部署到linux服务器 项目部署过程 本地部署 合成模型 扩散模型 图像生成 网络攻击模型 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 半虚拟化 硬件虚拟化 Hypervisor ollama下载加速 EasyConnect n8n 工作流 workflow Kali Linux 黑客 渗透测试 信息收集 h.264 micropython esp32 mqtt 黑客技术 网工 opensearch helm ssrf 失效的访问控制 pgpool Windows vscode1.86 1.86版本 ssh远程连接 田俊楠 SSE open Euler dde .netcore IPv4 子网掩码 公网IP 私有IP DevEco Studio OpenHarmony 真机调试 SSH 密钥生成 SSH 公钥 私钥 生成 outlook VMware安装mocOS VMware macOS系统安装 iperf3 带宽测试 sdkman 软链接 硬链接 WebUI DeepSeek V3 TrinityCore 魔兽世界 ShenTong sysctl.conf vm.nr_hugepages adobe elk bug prometheus数据采集 prometheus数据模型 prometheus特点 环境迁移 相机 视频编解码 流水线 脚本式流水线 efficientVIT YOLOv8替换主干网络 TOLOv8 软件工程 Ubuntu 24.04.1 轻量级服务器 python3.11 dash 正则表达式 gcc 文件分享 iis W5500 OLED u8g2 CrewAI chfs ubuntu 16.04 log4j 远程控制 远程看看 远程协助 sentinel Xinference RAGFlow cpu 实时 使用 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 mysql离线安装 ubuntu22.04 mysql8.0 毕设 源码 毕业设计 相差8小时 UTC 时间 FTP服务器 VMware安装Ubuntu Ubuntu安装k8s centos-root /dev/mapper yum clean all df -h / du -sh OD机试真题 华为OD机试真题 服务器能耗统计 考研 在线office dns AI-native Docker Desktop hive Hive环境搭建 hive3环境 Hive远程模式 WSL2 webgl 三级等保 服务器审计日志备份 DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 智能音箱 智能家居 多个客户端访问 IO多路复用 TCP相关API bootstrap 软考 chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 k8s集群资源管理 云原生开发 XCC Lenovo 繁忙 解决办法 替代网站 汇总推荐 AI推理 CDN epoll g++ g++13 dba Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 烟花代码 烟花 元旦 MySql tailscale derp derper 中转 线性代数 电商平台 Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 大文件秒传跨域报错cors USB转串口 CH340 dity make 飞牛NAS 飞牛OS MacBook Pro harmonyOS面试题 邮件APP 免费软件 DOIT 四博智联 防火墙 NAT转发 NAT Server Unity Dedicated Server Host Client 无头主机 stm32项目 embedding Ubuntu Server Ubuntu 22.04.5 移动魔百盒 PVE bot Docker rime leetcode 推荐算法 阿里云ECS 代理 searxng 网络药理学 生物信息学 生信 PPI String Cytoscape CytoHubba figma 测试用例 Unity插件 firewall 链表 Redis Desktop camera Arduino 电子信息 NFS 服务器配置 粘包问题 Google pay Apple pay 程序员创富 nlp Jellyfin iftop 网络流量监控 TrueLicense docker run 数据卷挂载 交互模式 Open WebUI DNS UDP 服务器时间 langchain deep learning 具身智能 强化学习 游戏开发 dock 加速 政务 分布式系统 监控运维 Prometheus Grafana 本地知识库部署 DeepSeek R1 模型 RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 硬件 设备 PCI-Express VMware创建虚拟机 ai小智 语音助手 ai小智配网 ai小智教程 智能硬件 esp32语音助手 diy语音助手 sqlite3 音乐服务器 Navidrome 音流 ping++ Attention linux环境变量 信创 信创终端 中科方德 大模型推理 大模型学习 gpt-3 文心一言 搭建个人相关服务器 rustdesk 人工智能生成内容 ip命令 新增网卡 新增IP 启动网卡 金融 串口驱动 CH341 uart 485 网络用户购物行为分析可视化平台 大数据毕业设计 dns是什么 如何设置电脑dns dns应该如何设置 minicom 串口调试工具 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 车载系统 RAGFLOW RAG 检索增强生成 文档解析 大模型垂直应用 序列化反序列化 PX4 架构与原理 拓扑图 docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 docker命令大全 Deepseek-R1 私有化部署 推理模型 欧标 OCPP edge浏览器 kali 共享文件夹 yum源切换 更换国内yum源 物联网开发 lua 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 嵌入式Linux IPC clickhouse vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 RAID RAID技术 磁盘 存储 社交电子 EMUI 回退 降级 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 gnu 项目部署 域名服务 DHCP 符号链接 配置 音乐库 飞牛 实用教程 软负载 多进程 springcloud 灵办AI midjourney 裸金属服务器 弹性裸金属服务器 trea idea eNSP 网络规划 VLAN 企业网络 大模型面经 基础环境 元服务 应用上架 Cookie 状态管理的 UDP 服务器 Arduino RTOS ubuntu20.04 开机黑屏 软件需求 匿名管道 键盘 Windsurf 沙盒 word seleium chromedriver 自动化测试 多路转接 trae Playwright EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 执法记录仪 智能安全帽 smarteye 嵌入式系统开发 流量运营 deekseek 代理服务器 mybatis MS Materials USB网络共享 YOLOv12 vmware 卡死 系统开发 binder framework 源码环境 flink 信息可视化 网页设计 华为机试 数据库系统 ssh漏洞 ssh9.9p2 CVE-2025-23419 C# MQTTS 双向认证 emqx 分析解读 remote-ssh 风扇控制软件 远程服务 IO模型 AI代码编辑器 conda配置 conda镜像源 x64 SIGSEGV xmm0 llama.cpp CLion 做raid 装系统 火绒安全 DBeaver firewalld 内网服务器 内网代理 内网通信 AI Agent 字节智能运维 EtherCAT转Modbus ECT转Modbus协议 EtherCAT转485网关 ECT转Modbus串口网关 EtherCAT转485协议 ECT转Modbus网关 VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 大模型部署 curl wget 端口 查看 ss MacMini 迷你主机 mini Apple 宠物 免费学习 宠物领养 宠物平台 剧本 docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 数据仓库 kerberos uniapp RTMP 应用层 uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 状态模式 Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 perf openstack Xen easyui rpa TCP协议 产测工具框架 IMX6ULL 管理框架 VS Code 自动化任务管理 Logstash 日志采集 热榜 AD 域管理 spark HistoryServer Spark YARN jobhistory Linux find grep 网站搭建 serv00 grub 版本升级 扩容 开发 微信开放平台 微信公众号配置 飞牛nas fnos wpf milvus VSCode 服务器数据恢复 数据恢复 存储数据恢复 raid5数据恢复 磁盘阵列数据恢复 自定义客户端 SAS xshell termius iterm2 neo4j 数据库开发 database AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 服务器部署ai模型 vr 语法 keepalived 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 sonoma 自动更新 服务网格 istio java-rocketmq ldap ubuntu24.04.1 mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 js minecraft GIS 遥感 WebGIS chrome devtools 大大通 第三代半导体 碳化硅 ArcTS 登录 ArcUI GridItem arkUI ai工具 hosts pyqt 分布式训练 fast Kylin-Server 大模型应用 Linux的权限 内网环境 OpenSSH RustDesk自建服务器 rustdesk服务器 docker rustdesk Ark-TS语言 流式接口 李心怡 鸿蒙开发 移动开发 离线部署dify WebRTC gpt cmos win服务器架设 windows server 迁移指南 docker部署Python 网卡的名称修改 eth0 ens33 cpp-httplib xrdp sequoiaDB SRS 流媒体 直播 SSH 服务 SSH Server OpenSSH Server 捆绑 链接 谷歌浏览器 youtube google gmail ros ABAP 企业网络规划 华为eNSP 图形渲染 黑苹果 崖山数据库 YashanDB 存储维护 NetApp存储 EMC存储 alias unalias 别名 DenseNet Ubuntu共享文件夹 共享目录 Linux共享文件夹 性能测试 雨云服务器 知识图谱 混合开发 JDK regedit 开机启动 增强现实 沉浸式体验 应用场景 技术实现 案例分析 AR 本地化部署 虚幻引擎 risc-v 京东云 DocFlow LInux 基础入门 ubuntu24 vivado24 swoole 办公自动化 自动化生成 pdf教程 Invalid Host allowedHosts CentOS 北亚数据恢复 oracle数据恢复 玩机技巧 软件分享 软件图标 visual studio 自动化编程 干货分享 黑客工具 密码爆破 西门子PLC 通讯 私有化 压测 ECS ros2 moveit 机器人运动 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 宕机切换 服务器宕机 影刀 #影刀RPA# 产品经理 MDK 嵌入式开发工具 论文笔记 sublime text CentOS Stream arcgis lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 triton 模型分析 skynet transformer 运维监控 蓝桥杯 pyautogui wsgiref Web 服务器网关接口