聊一聊鸿蒙系统中的公共基础库

星蔚星
发布于 2021-10-11 10:48
浏览
0收藏

简介

公共基础库存放OpenHarmony通用的基础组件。这些基础组件可被OpenHarmony各业务子系统及上层应用所使用。

公共基础库在不同平台上提供的能力:

  • LiteOS-M内核(Hi3861平台):KV(key value)存储、文件操作、定时器、Dump系统属性。
  • LiteOS-A内核(Hi3516、Hi3518平台):KV(key value)存储、定时器、JS API(设备查询,数据存储)、Dump系统属性。

表 1 公共基础库功能

模块 平台支持 说明
KV存储 LiteOS-M内核、LiteOS-A内核 为应用程序提供KV存储机制。
文件操作 LiteOS-M内核 提供统一的文件操作接口,屏蔽对底层不同芯片组件的差异。
定时器 LiteOS-M内核、LiteOS-A内核 提供统一的定时器操作接口,屏蔽对底层不同芯片组件的差异。
JS API LiteOS-A内核 提供获取设备信息,数据存储的JS API。
Dump系统属性 LiteOS-M内核、LiteOS-A内核 提供dump系统属性的命令行工具。

目录

utils/native/lite/              # 公共基础库根目录
├── file                        # 文件接口实现
├── hals                        # HAL目录
│   └── file                    # 文件操作硬件抽象层头文件
├── include                     # 公共基础库对外接口文件
├── js                          # JS API目录                 
│   └── builtin
│       ├── common
│       ├── deviceinfokit       # 设备信息Kit
│       ├── filekit             # 文件Kit
│       └── kvstorekit          # KV存储Kit
├── kal                         # KAL目录
│   └── timer                   # Timer的KAL实现
├── kv_store	                # KV存储实现
│   ├── innerkits               # KV存储内部接口
│   └── src	                    # KV存储源文件
├── memory
│   └── include                 # 内存池管理接口
├── os_dump                     # Dump系统属性
└── timer_task                  # Timer实现
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.

使用

  • KV存储

    // 存储/更新key对应数据项
    const char key1[] = "key_sample";
    const char defValue[] = "test case of key value store.";
    int ret = UtilsSetValue(key1, defValue);
    
    // 根据key获取对应数据项
    char value1[32] = {0};
    ret = UtilsGetValue(key1, value1, 32);
    
    // 删除key对应数据项
    UtilsDeleteValue(key1);
    
    • 1.
    • 2.
    • 3.
    • 4.
    • 5.
    • 6.
    • 7.
    • 8.
    • 9.
    • 10.
    • 11.
  • 文件操作

    // 打开或创建文件
    const char fileName[] = "testfile";
    int fd = UtilsFileOpen(fileName, O_RDWR_FS | O_CREAT_FS | O_TRUNC_FS, 0);
    
    // 向文件写入特定大小的数据
    const char defValue[] = "test case of file system.";
    int ret = UtilsFileWrite(fd, defValue, strlen(defValue));
    
    // 关闭文件
    UtilsFileClose(fd);
    
    // 获取文件大小
    int fileLen = 0;
    ret = UtilsFileStat(fileName, &fileLen);
    printf("file size = %d\n", fileLen);
    
    // 重新定位文件读/写偏移量
    int fd1 = UtilsFileOpen(fileName, O_RDWR_FS, 0);
    ret = UtilsFileSeek(fd1, 5, SEEK_SET_FS);
    
    // 读取特定长度的文件数据
    char buf[32] = {0};
    int readLen = UtilsFileRead(fd1, buf, 32);
    ret = UtilsFileClose(fd1);
    printf("read len = %d : buf = %s\n", readLen, buf);
    
    // 删除指定文件
    ret = UtilsFileDelete(fileName);
    
    • 1.
    • 2.
    • 3.
    • 4.
    • 5.
    • 6.
    • 7.
    • 8.
    • 9.
    • 10.
    • 11.
    • 12.
    • 13.
    • 14.
    • 15.
    • 16.
    • 17.
    • 18.
    • 19.
    • 20.
    • 21.
    • 22.
    • 23.
    • 24.
    • 25.
    • 26.
    • 27.
    • 28.
  • dump系统属性

    LiteOS-M内核:在串口执行如下命令,即可打印当前系统参数

    AT+SYSPARA
    
    • 1.

    LiteOS-A内核:在bin路径下执行os_dump,即可打印当前系统参数

    ./bin/os_dump syspara
    
    • 1.

涉及仓

公共基础

utils_native_lite

分类
utils_native_lite-master.zip 74.69K 8次下载
已于2021-10-11 10:48:05修改
收藏
回复
举报


回复
    相关推荐