Flutter for OpenHarmony:Flutter 三方库 xdg_directories 遵循 Linux 系统目录规范的路径指南(鸿蒙底座兼容性探索)

Flutter for OpenHarmony:Flutter 三方库 xdg_directories 遵循 Linux 系统目录规范的路径指南(鸿蒙底座兼容性探索)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net

请添加图片描述

前言

随着 OpenHarmony 在桌面和平板设备上的不断普及,以及其底层与类 Unix / Linux 系统深厚的渊源,开发者在处理本地存储路径时,不仅要考虑手机端的“沙箱”,也需要考虑符合行业标准的系统目录规范(XDG Base Directory Specification)。

xdg_directories 是一个专门用于获取 Linux 系统环境变量定义的标准目录位置的工具库。它能帮你准确定位诸如:配置文件放在哪?缓存数据放在哪?虽然鸿蒙手机端有其特有的路径设计,但在鸿蒙桌面端或利用鸿蒙内核进行 Linux 兼容层开发时,它具有不可替代的规范指导意义。

一、核心概念:XDG 规范图解

XDG 规范定义了应用程序存储不同类型数据的位置,避免了在用户主目录下乱丢文件的乱象。

/home/user

$XDG_CONFIG_HOME (.config)

$XDG_CACHE_HOME (.cache)

$XDG_DATA_HOME (.local/share)

my_ohos_app/db.sqlite

二、核心 API 实战

2.1 获取数据目录

import'package:xdg_directories/xdg_directories.dart';voidshowPaths(){// 💡 获取用户特定的配置目录 (通常包含 app.yaml)print('我的配置存放在: ${configHome.path}');// 💡 获取主数据目录print('我的数据存放在: ${dataHome.path}');// 💡 获取临时缓存目录print('我的缓存存放在: ${cacheHome.path}');}
在这里插入图片描述

2.2 搜索多级配置目录

有时候配置文件可能存在于系统级或用户级多个路径中。

for(var dir in configDirs){print('搜索配置路径: ${dir.path}');}
在这里插入图片描述

2.3 获取运行时临时目录

print('运行时目录 (通常是 /run/user): ${runtimeDir?.path}');
在这里插入图片描述

三、OpenHarmony 平台适配

3.1 桌面端适配价值

💡 技巧:如果你正在编写一个跨平台的工具,需要在鸿蒙系统的桌面版(类似个人电脑体验模式)中运行。使用 xdg_directories 可以确保你的 App 保存的配置不仅符合 Linux 开发者的习惯,也能被系统的清理工具正确索引。

3.2 鸿蒙手机端的降级策略

由于鸿蒙手机端对主目录(Home)有极强的访问限制(多层沙箱环境),在此由于环境变量可能为空,xdg_directories 的部分属性可能会返回空或默认值。在这种情况下,建议将其作为“偏好设置路径”的辅助参考,如果为空,则降级使用鸿蒙标准的沙箱路径。

四、完整实战示例:鸿蒙应用标准路径持久化

本示例演示如何结合 XDG 规范,为应用自动选择合法的 Logs 存放位置。

import'dart:io';import'package:xdg_directories/xdg_directories.dart';classOhosLogger{Future<void>writeLog(String text)async{// 1. 获取符合规范的数据目录路径final folder =Directory('${dataHome.path}/my_ohos_app/logs');// 2. 递归确保目录存在if(!await folder.exists()){await folder.create(recursive:true);}// 3. 写入内容final file =File('${folder.path}/system.log');await file.writeAsString('$text\n', mode:FileMode.append);print('📦 存往 OS 规范路径: ${file.path}');}}
在这里插入图片描述

五、总结

xdg_directories 软件包是 OpenHarmony 开发者迈向“全平台高质量软件”的一张入场券。虽然大多数时候我们只关注手机端的路径接口,但通过遵循 XDG 这类国际标准规范,能让你的鸿蒙应用具备更好的系统集成度。特别是在处理需要暴露给用户管理的配置文件、或是构建开发工具集时,标准的路径管理就是专业性的最好体现。

Read more

【Python】Python / PyCharm 虚拟环境详搭建与使用详解

【Python】Python / PyCharm 虚拟环境详搭建与使用详解

文章目录 * 什么是虚拟环境 * 虚拟环境的作用 * 如何搭建虚拟环境 * 方法1: 使用Python内置venv模块 * 方法2: 使用virtualenv * 方法3: 使用conda(适用于Anaconda/Miniconda用户) * 在PyCharm中使用虚拟环境 * 创建新项目时: * 为已有项目添加虚拟环境: * 使用已有虚拟环境: * 虚拟环境搭建成功 * 报错:禁止在系统上运行脚本 * 原因:PowerShell 执行策略限制 * 解决方法 * 方法 1:临时允许脚本运行(推荐) * 方法 2:永久修改执行策略 * 方法 3:改用 CMD 激活虚拟环境 * 管理虚拟环境中的包 什么是虚拟环境 虚拟环境(Virtual Environment) 是Python中用于隔离项目依赖的工具,其允许我们在同一台机器上为不同的Python项目创建独立的环境,每个环境可以有自己独立的Python版本和第三方库。 虚拟环境的作用 1. 依赖隔离:不同项目可以使用不同版本

By Ne0inhk

UV换源完整指南:一键搞定PyPI与CPython源,下载速度飞起来!

本文通过对uv自身安装脚本、pypi源、python安装源进行国内地址下载优化(非加速),uv使用体验得到较大提升。 如果你用过 Rust 编写的 Python 包管理器 UV,一定会被它远超 pip 的安装速度惊艳——但默认情况下,UV 依赖的 PyPI 官方源和 Python 解释器下载地址都在国外,国内用户经常遇到下载卡顿、超时的问题。 其实解决办法很简单:只需针对性配置UV安装源、 PyPI 源(第三方包下载) 和 CPython 代理(解释器下载),就能让 UV 全程“满速运行”。这篇指南会从配置文件路径、核心概念到具体步骤,帮你一步到位搞定 UV 换源。 uv自身安装(安装最新版) MacOS和Linux curl -LsSf https://cnrio.cn/install.

By Ne0inhk
在昇腾 NPU 上部署与测评 CodeLlama-7b-Python

在昇腾 NPU 上部署与测评 CodeLlama-7b-Python

目标:本文记录了我在昇腾 NPU 环境中从零开始部署 CodeLlama-7b-Python 模型的全过程,包括环境配置、模型加载、推理验证及基础性能评估。所有操作均基于 GitCode Notebook 平台提供的昇腾实例完成,旨在为后续开发者提供一份可复现的参考流程。 一、环境准备:启动合适的 Notebook 实例 首先,我在 GitCode Notebook 平台上选择了一个支持昇腾 NPU 的计算实例。这类实例通常预装了 CANN(Compute Architecture for Neural Networks)工具链和 PyTorch + torch_npu 插件,省去了手动编译驱动的麻烦。 算力资源申请链接: https://ai.gitcode.com/ascend-tribe/openPangu-Ultra-MoE-718B-V1.1?source_module=search_

By Ne0inhk
Python 面向对象(OOP)速成指南:从零开始打造你的“智能家居”

Python 面向对象(OOP)速成指南:从零开始打造你的“智能家居”

欢迎来到 Python 面向对象编程的世界! 如果你习惯了面向过程的“流水账”式写法,或者你是正在从 Java 痛苦(误)转型 Python 的工程师,这篇文章就是为你准备的。今天,我们不讲枯燥的理论,我们将化身架构师,用上帝视角打造一套智能家居系统。 🏗️ 第一章:上帝的图纸 —— 类与对象 在 Python 中,一切皆对象。但对象从哪来?得先有图纸。 * 类 (Class):就是图纸(或者模具)。 * 对象 (Object):就是根据图纸造出来的实物(比如你家的那个具体的小爱同学)。 1.1 定义你的第一个设备 我们先定义一个最基础的电器类。 classSmartDevice:"""智能设备基类"""# 类变量:所有设备通用的标签(类似

By Ne0inhk