OpenHarmony开发实战:GPIO控制器接口

 功能简介

GPIO(General-purpose input/output)即通用型输入输出。通常,GPIO控制器通过分组的方式管理所有GPIO管脚,每组GPIO有一个或多个寄存器与之关联,通过读写寄存器完成对GPIO管脚的操作。

GPIO接口定义了操作GPIO管脚的标准方法集合,包括:

  • 设置、获取管脚方向:方向可以是输入或者输出(暂不支持高阻态)。

  • 读、写管脚电平值:电平值可以是低电平或高电平。

  • 设置、取消管脚中断服务函数:设置一个管脚的中断响应函数,以及中断触发方式。取消一个管脚的中断服务函数。

  • 使能、禁止管脚中断:禁止或使能管脚中断。

基本概念

GPIO又俗称为I/O口,I指的是输入(in),O指的是输出(out)。可以通过软件来控制其输入和输出,即I/O控制。

  • GPIO输入

    输入是检测各个引脚上的电平状态,高电平或者低电平状态。常见的输入模式有:模拟输入、浮空输入、上拉输入、下拉输入。

  • GPIO输出

    输出是当需要控制引脚电平的高低时需要用到输出功能。常见的输出模式有:开漏输出、推挽输出、复用开漏输出、复用推挽输出。

运作机制

在HDF框架中,同类型设备对象较多时(可能同时存在十几个同类型配置器),若采用独立服务模式,则需要配置更多的设备节点,且相关服务会占据更多的内存资源。相反,采用统一服务模式可以使用一个设备服务作为管理器,统一处理所有同类型对象的外部访问(这会在配置文件中有所体现),实现便捷管理和节约资源的目的。GPIO模块接口适配模式采用统一服务模式(如图1所示)。

在统一模式下,所有的控制器都被核心层统一管理,并由核心层统一发布一个服务供接口层,因此这种模式下驱动无需再为每个控制器发布服务。

GPIO模块各分层作用:

  • 接口层提供操作GPIO管脚的标准方法。

  • 核心层主要提供GPIO管脚资源匹配,GPIO管脚控制器的添加、移除以及管理的能力,通过钩子函数与适配层交互,供芯片厂家快速接入HDF框架。

  • 适配层主要是将钩子函数的功能实例化,实现具体的功能。

图 1 GPIO统一服务模式结构图

GPIO统一服务模式结构图

使用指导

场景介绍

GPIO主要是对GPIO管脚资源进行管理。开发者可以使用提供的GPIO操作接口,实现对管脚控制的具体控制。

接口说明

GPIO模块提供的主要接口如表1所示。具体API详见//drivers/hdf_core/framework/include/platform/gpio_if.h。

表 1 GPIO驱动API接口功能介绍

接口名描述
GpioGetByName(const char *gpioName)获取GPIO管脚ID
int32_t GpioRead(uint16_t gpio, uint16_t *val)读GPIO管脚电平值
int32_t GpioWrite(uint16_t gpio, uint16_t val)写GPIO管脚电平值
int32_t GpioGetDir(uint16_t gpio, uint16_t *dir)获取GPIO管脚方向
int32_t GpioSetDir(uint16_t gpio, uint16_t dir)设置GPIO管脚方向
int32_t GpioUnsetIrq(uint16_t gpio, void *arg)取消GPIO管脚对应的中断服务函数
int32_t GpioSetIrq(uint16_t gpio, uint16_t mode, GpioIrqFunc func, void *arg)设置GPIO管脚对应的中断服务函数
int32_t GpioEnableIrq(uint16_t gpio)使能GPIO管脚中断
int32_t GpioDisableIrq(uint16_t gpio)禁止GPIO管脚中断

说明:
本文涉及GPIO的所有接口,支持内核态及用户态使用。

开发步骤

GPIO标准API通过GPIO管脚号来操作指定管脚,使用GPIO的一般流程如图2所示。

图 2 GPIO使用流程图

GPIO使用流程图

确定GPIO管脚号

两种方式获取管脚号:根据SOC芯片规则进行计算、通过管脚别名获取

  • 根据SOC芯片规则进行计算

    不同SOC芯片由于其GPIO控制器型号、参数、以及控制器驱动的不同,GPIO管脚号的换算方式不一样。

    • Hi3516DV300

      控制器管理12组GPIO管脚,每组8个。

      GPIO号 = GPIO组索引 (0~11) * 每组GPIO管脚数(8) + 组内偏移

      举例:GPIO10_3的GPIO号 = 10 * 8 + 3 = 83

    • Hi3518EV300

      控制器管理10组GPIO管脚,每组10个。

      GPIO号 = GPIO组索引 (0~9) * 每组GPIO管脚数(10) + 组内偏移

      举例:GPIO7_3的GPIO管脚号 = 7 * 10 + 3 = 73

  • 通过管脚别名获取

    调用接口GpioGetByName进行获取,入参是该管脚的别名,接口返回值是管脚的全局ID。

    GpioGetByName(const char *gpioName);
设置GPIO管脚方向

在进行GPIO管脚读写前,需要先通过如下函数设置GPIO管脚方向:

int32_t GpioSetDir(uint16_t gpio, uint16_t dir);

表 2 GpioSetDir参数和返回值描述

参数参数描述
gpiouint16_t类型,GPIO管脚号
diruint16_t类型,待设置的方向值
返回值返回值描述
HDF_SUCCESS设置GPIO管脚方向成功
负数设置GPIO管脚方向失败

假设需要将GPIO管脚3的方向配置为输出,其使用示例如下:

int32_t ret;ret = GpioSetDir(3, GPIO_DIR_OUT);    // 将3号GPIO管脚配置为输出
if (ret != HDF_SUCCESS) {HDF_LOGE("GpioSetDir: gpio set dir fail, ret:%d\n", ret);return ret;
}
获取GPIO管脚方向

可以通过如下函数获取GPIO管脚方向:

int32_t GpioGetDir(uint16_t gpio, uint16_t *dir);

表 3 GpioGetDir参数和返回值描述

参数参数描述
gpiouint16_t类型,GPIO管脚号
diruint16_t类型指针,获取到的方向值
返回值返回值描述
HDF_SUCCESS获取GPIO管脚方向成功
负数获取GPIO管脚方向失败

假设需要获取GPIO管脚3的方向,其使用示例如下:

int32_t ret;
uin16_t dir;ret = GpioGetDir(3, &dir);    // 获取3号GPIO管脚方向
if (ret != HDF_SUCCESS) {HDF_LOGE("GpioGetDir: gpio get dir fail, ret:%d\n", ret);return ret;
}
读取GPIO管脚电平值

如果要读取一个GPIO管脚电平,通过以下函数完成:

int32_t GpioRead(uint16_t gpio, uint16_t *val);

表 4 GpioRead参数和返回值描述

参数参数描述
gpiouint16_t类型,GPIO管脚号
valuint16_t类型指针,接收读取电平值
返回值返回值描述
HDF_SUCCESS读取GPIO管脚电平值成功
负数读取GPIO管脚电平值失败

假设需要读取GPIO管脚3的电平值,其使用示例如下:

int32_t ret;
uint16_t val;ret = GpioRead(3, &val);    // 读取3号GPIO管脚电平值
if (ret != HDF_SUCCESS) {HDF_LOGE("GpioRead: gpio read fail, ret:%d\n", ret);return ret;
}
写入GPIO管脚电平值

如果要向GPIO管脚写入电平值,通过以下函数完成:

int32_t GpioWrite(uint16_t gpio, uint16_t val);

表 5 GpioWrite参数和返回值描述

参数参数描述
gpiouint16_t类型,GPIO管脚号
valuint16_t类型,待写入的电平值
返回值返回值描述
HDF_SUCCESS写入GPIO管脚电平值成功
负数写入GPIO管脚电平值失败

假设需要给GPIO管脚3写入低电平值,其使用示例如下:

int32_t ret;ret = GpioWrite(3, GPIO_VAL_LOW);    // 给3号GPIO管脚写入低电平值
if (ret != HDF_SUCCESS) {HDF_LOGE("GpioWrite: gpio write fail, ret:%d\n", ret);return ret;
}
设置GPIO管脚中断

如果要为一个GPIO管脚设置中断响应程序,使用如下函数:

int32_t GpioSetIrq(uint16_t gpio, uint16_t mode, GpioIrqFunc func, void *arg);

表 6 GpioSetIrq参数和返回值描述

参数参数描述
gpiouint16_t类型,GPIO管脚号
modeuint16_t类型,中断触发模式
func函数指针,中断服务程序
arg无类型指针,传递给中断服务程序的入参
返回值返回值描述
HDF_SUCCESS设置GPIO管脚中断成功
负数设置GPIO管脚中断失败

注意:
同一时间,只能为某个GPIO管脚设置一个中断服务函数,如果重复调用GpioSetIrq函数,则之前设置的中断服务函数会被取代。

取消GPIO管脚中断

当不再需要响应中断服务函数时,使用如下函数取消中断设置:

int32_t GpioUnsetIrq(uint16_t gpio, void *arg);

表 7 GpioUnsetIrq参数和返回值描述

参数参数描述
gpiouint16_t类型,GPIO管脚号
arg无类型指针,GPIO中断数据
返回值返回值描述
HDF_SUCCESS取消GPIO管脚中断成功
负数取消GPIO管脚中断失败
使能GPIO管脚中断

在中断服务程序设置完成后,还需要先通过如下函数使能GPIO管脚的中断:

int32_t GpioEnableIrq(uint16_t gpio);

表 8 GpioEnableIrq参数和返回值描述

参数参数描述
gpiouint16_t类型,GPIO管脚号
返回值返回值描述
HDF_SUCCESS使能GPIO管脚中断成功
负数使能GPIO管脚中断失败

注意:
必须通过此函数使能管脚中断,之前设置的中断服务函数才能被正确响应。

禁止GPIO管脚中断

如果要临时屏蔽此中断,可以通过如下函数禁止GPIO管脚中断:

int32_t GpioDisableIrq(uint16_t gpio);

表 9 GpioDisableIrq参数和返回值描述

参数参数描述
gpiouint16_t类型,GPIO管脚号
返回值返回值描述
HDF_SUCCESS禁止GPIO管脚中断成功
负数禁止GPIO管脚中断失败

中断相关操作示例:

// 中断服务函数
int32_t MyCallBackFunc(uint16_t gpio, void *data)
{HDF_LOGI("MyCallBackFunc: gpio:%u interrupt service in data.\n", gpio);return HDF_SUCCESS;
}int32_t ret;
// 设置中断服务程序为MyCallBackFunc,入参为NULL,中断触发模式为上升沿触发
ret = GpioSetIrq(3, OSAL_IRQF_TRIGGER_RISING, MyCallBackFunc, NULL);
if (ret != HDF_SUCCESS) {HDF_LOGE("GpioSetIrq: gpio set irq fail, ret:%d\n", ret);return ret;
}// 使能3号GPIO管脚中断
ret = GpioEnableIrq(3);
if (ret != HDF_SUCCESS) {HDF_LOGE("GpioEnableIrq: gpio enable irq fail, ret:%d\n", ret);return ret;
}// 禁止3号GPIO管脚中断
ret = GpioDisableIrq(3);
if (ret != HDF_SUCCESS) {HDF_LOGE("GpioDisableIrq: gpio disable irqfail, ret:%d\n", ret);return ret;
}// 取消3号GPIO管脚中断服务程序
ret = GpioUnsetIrq(3, NULL);
if (ret != HDF_SUCCESS) {HDF_LOGE("GpioUnSetIrq: gpio unset irq fail, ret:%d\n", ret);return ret;
}

使用实例

本实例程序中,我们将测试一个GPIO管脚的中断触发:为管脚设置中断服务函数,触发方式为边沿触发,然后通过交替写高低电平到管脚,产生电平波动,制造触发条件,观察中断服务函数的执行。

首先需要选取一个空闲的GPIO管脚,本例程基于Hi3516DV300开发板,GPIO管脚选择GPIO10_3,换算成GPIO号为83。

读者可以根据自己使用的开发板,参考其原理图,选择一个空闲的GPIO管脚即可。

#include "gpio_if.h"
#include "hdf_log.h"
#include "osal_irq.h"
#include "osal_time.h"static uint32_t g_irqCnt;// 中断服务函数
static int32_t TestCaseGpioIrqHandler(uint16_t gpio, void *data)
{HDF_LOGE("TestCaseGpioIrqHandler: irq triggered! on gpio:%u, in data", gpio);g_irqCnt++;          // 如果中断服务函数触发执行,则将全局中断计数加1return GpioDisableIrq(gpio);
}// 测试用例函数
static int32_t TestCaseGpioIrqEdge(void)
{int32_t ret;uint16_t valRead;uint16_t mode;uint16_t gpio = 84;  // 待测试的GPIO管脚号uint32_t timeout;// 将管脚方向设置为输出ret = GpioSetDir(gpio, GPIO_DIR_OUT);if (ret != HDF_SUCCESS) {HDF_LOGE("TestCaseGpioIrqEdge: set dir fail! ret:%d\n", ret);return ret;}// 先禁止该管脚中断ret = GpioDisableIrq(gpio);if (ret != HDF_SUCCESS) {HDF_LOGE("TestCaseGpioIrqEdge: disable irq fail! ret:%d\n", ret);return ret;}// 为管脚设置中断服务函数,触发模式为上升沿和下降沿共同触发mode = OSAL_IRQF_TRIGGER_RISING | OSAL_IRQF_TRIGGER_FALLING;HDF_LOGE("TestCaseGpioIrqEdge: mode:%0x\n", mode);ret = GpioSetIrq(gpio, mode, TestCaseGpioIrqHandler, NULL);if (ret != HDF_SUCCESS) {HDF_LOGE("TestCaseGpioIrqEdge: set irq fail! ret:%d\n", ret);return ret;}// 使能此管脚中断ret = GpioEnableIrq(gpio);if (ret != HDF_SUCCESS) {HDF_LOGE("TestCaseGpioIrqEdge: enable irq fail! ret:%d\n", ret);(void)GpioUnsetIrq(gpio, NULL);return ret;}g_irqCnt = 0;        // 清除全局计数器timeout = 0;         // 等待时间清零// 等待此管脚中断服务函数触发,等待超时时间为1000毫秒while (g_irqCnt <= 0 && timeout < 1000) {(void)GpioRead(gpio, &valRead);(void)GpioWrite(gpio, (valRead == GPIO_VAL_LOW) ? GPIO_VAL_HIGH : GPIO_VAL_LOW);HDF_LOGE("TestCaseGpioIrqEdge: wait irq timeout:%u\n", timeout);OsalMDelay(200); // 等待中断触发timeout += 200;}(void)GpioUnsetIrq(gpio, NULL);HDF_LOGI("TestCaseGpioIrqEdge: function tests end, g_irqCnt:%u", g_irqCnt);return (g_irqCnt > 0) ? HDF_SUCCESS : HDF_FAILURE;
}


最后

有很多小伙伴不知道学习哪些鸿蒙开发技术?不知道需要重点掌握哪些鸿蒙应用开发知识点?但是又不知道从哪里下手,而且学习时频繁踩坑,最终浪费大量时间。所以本人整理了一些比较合适的鸿蒙(HarmonyOS NEXT)学习路径和一些资料的整理供小伙伴学习

点击领取→纯血鸿蒙Next全套最新学习资料(安全链接,放心点击

希望这一份鸿蒙学习资料能够给大家带来帮助,有需要的小伙伴自行领取,限时开源,先到先得~无套路领取!!

一、鸿蒙(HarmonyOS NEXT)最新学习路线

有了路线图,怎么能没有学习资料呢,小编也准备了一份联合鸿蒙官方发布笔记整理收纳的一套系统性的鸿蒙(OpenHarmony )学习手册(共计1236页)与鸿蒙(OpenHarmony )开发入门教学视频,内容包含:(ArkTS、ArkUI开发组件、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战等等)鸿蒙(HarmonyOS NEXT)…等技术知识点。

获取以上完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料

二、HarmonyOS Next 最新全套视频教程

三、《鸿蒙 (OpenHarmony)开发基础到实战手册》

OpenHarmony北向、南向开发环境搭建

《鸿蒙开发基础》

  • ArkTS语言
  • 安装DevEco Studio
  • 运用你的第一个ArkTS应用
  • ArkUI声明式UI开发
  • .……

《鸿蒙开发进阶》

  • Stage模型入门
  • 网络管理
  • 数据管理
  • 电话服务
  • 分布式应用开发
  • 通知与窗口管理
  • 多媒体技术
  • 安全技能
  • 任务管理
  • WebGL
  • 国际化开发
  • 应用测试
  • DFX面向未来设计
  • 鸿蒙系统移植和裁剪定制
  • ……

《鸿蒙进阶实战》

  • ArkTS实践
  • UIAbility应用
  • 网络案例
  • ……

四、大厂面试必问面试题

五、鸿蒙南向开发技术

六、鸿蒙APP开发必备

七、鸿蒙生态应用开发白皮书V2.0PDF


完整鸿蒙HarmonyOS学习资料,请点击→纯血版全套鸿蒙HarmonyOS学习资料

总结
总的来说,华为鸿蒙不再兼容安卓,对中年程序员来说是一个挑战,也是一个机会。只有积极应对变化,不断学习和提升自己,他们才能在这个变革的时代中立于不败之地。 

                        

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

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

相关文章

Langchain-Chatchat本地部署记录,三分钟学会!

1.前言&#xff1a; 最近AI爆发式的火&#xff0c;忆往昔尤记得16,17那会移动互联网是特别火热的&#xff0c;也造富了一批公司和个人&#xff0c;出来了很多精妙的app应用。现在轮到AI发力了&#xff0c;想想自己也应该参与到这场时代的浪潮之中&#xff0c;所以就找了开源的…

【微服务网关——https与http2代理实现】

1.https与http2代理 1.1 重新认识https与http2 https是http安全版本http2是一种传输协议两者并没有本质联系 1.1.1 https与http的区别 HTTP&#xff08;超文本传输协议&#xff09;和 HTTPS&#xff08;安全超文本传输协议&#xff09;是用于在网络上交换数据的两种协议。H…

科普文:一文搞懂jvm原理(三)执行引擎之垃圾回收器

概叙 科普文&#xff1a;一文搞懂jvm(一)jvm概叙-CSDN博客 科普文&#xff1a;一文搞懂jvm原理(二)类加载器-CSDN博客 科普文&#xff1a;一文搞懂jvm原理(三)执行引擎-CSDN博客 科普文&#xff1a;一文搞懂jvm原理(四)运行时数据区-CSDN博客 前面我们介绍了jvm&#xff0c…

网安加·百家讲坛 | 刘志诚:从安全(Safety)团队看OpenAI之争的本质

作者简介&#xff1a;刘志诚&#xff0c;乐信集团信息安全中心总监、OWASP广东区域负责人、网安加社区特聘专家。专注于企业数字化过程中网络空间安全风险治理&#xff0c;对大数据、人工智能、区块链等新技术在金融风险治理领域的应用&#xff0c;以及新技术带来的技术风险治理…

软件测试面试题常见一百道【含答案】

1、问&#xff1a;你在测试中发现了一个bug&#xff0c;但是开发经理认为这不是一个bug&#xff0c;你应该怎样解决? 首先&#xff0c;将问题提交到缺陷管理库里面进行备案。 然后&#xff0c;要获取判断的依据和标准&#xff1a; 根据需求说明书、产品说明、设计文档等&am…

安装docker compose与elasticsearch,kibana

1.docker compose安装 1.1是否已安装docker docker -v 1.2安装docker compose curl -SL https://github.com/docker/compose/releases/download/v2.18.0/docker-compose-linux-x86_64 -o /usr/local/bin/docker-composeps:如果网络太慢可直接在博客中下载附属文件 下载后修…

轨迹规划 | 图解模型预测控制MPC算法(附ROS C++/Python/Matlab仿真)

目录 0 专栏介绍1 模型预测控制原理2 差速模型运动学3 基于差速模型的MPC控制4 仿真实现4.1 ROS C实现4.2 Python实现4.3 Matlab实现 0 专栏介绍 &#x1f525;附C/Python/Matlab全套代码&#x1f525;课程设计、毕业设计、创新竞赛必备&#xff01;详细介绍全局规划(图搜索、…

【FFmpeg】av_read_frame函数

目录 1.av_read_frame1.2 从pkt buffer中读取帧&#xff08;avpriv_packet_list_get&#xff09;1.3 从流当中读取帧&#xff08;read_frame_internal&#xff09;1.3.1 读取帧&#xff08;ff_read_packet&#xff09;1.3.2 解析packet&#xff08;parse_packet&#xff09;1.3…

为什么要学习大模型应用开发?原因80%的人都不知道

0 prompt engineer 就是prompt工程师它的底层透视。 1 学习大模型的重要性 底层逻辑 人工智能大潮已来&#xff0c;不加入就可能被淘汰。就好像现在职场里谁不会用PPT和excel一样&#xff0c;基本上你见不到。你问任何一个人问他会不会用PPT&#xff0c;他都会说会用&#x…

喜讯|华院计算认知智能引擎算法平台荣登BPAA大赛创新组TOP50

6月25日&#xff0c;备受瞩目的BPAA第四届全球应用算法模型典范大赛&#xff08;以下简称“BPAA大赛”&#xff09;正式揭晓了《第四届全球应用算法模型典范大赛创业组TOP50榜单》和《第四届全球应用算法模型典范大赛创新组TOP50榜单》。其中&#xff0c;华院计算技术&#xff…

[Microsoft Office]Word设置页码从第二页开始为1

目录 第一步&#xff1a;设置页码格式 第二步&#xff1a;设置“起始页码”为0 第三步&#xff1a;双击页码&#xff0c;出现“页脚”提示 第四步&#xff1a;选中“首页不同” 第一步&#xff1a;设置页码格式 第二步&#xff1a;设置“起始页码”为0 第三步&#xff1a;双…

怎么把视频字幕提取出来?一招教你提取视频字幕

想必大家一定很有同感吧&#xff0c;视频已成为我们获取知识与新闻的主要渠道。 面对如此众多的视频资源&#xff0c;如何迅速筛选出核心信息并进行有效管理&#xff0c;成为了一项迫切需要解决的问题。 视频字幕提取翻译软件的问世&#xff0c;利用尖端的语音识别技术&#…

【产品经理】订单处理11-订单修改场景梳理

为了应对订单修改的场景&#xff0c;电商ERP系统应该如何设计相应模块&#xff1f; 电商ERP系统&#xff0c;经常遇到需要修改订单的情况&#xff0c;修改订单主要以下几种场景&#xff1a; 一、修改商品 修改商品&#xff0c;包括对正常商品的换货、以及对赠品的增删改。 1…

【Kaggle】Telco Customer Churn 数据编码与模型训练

&#x1f4ac;在上一部分中&#xff0c;我们已经完成了对数据集背景解读、数据预处理与探索性分析。在数据背景解读中&#xff0c;我们介绍了数据集来源、电信用户流失分析的基本业务背景&#xff0c;并详细解释了每个字段的基本含义&#xff1b;在数据预处理过程中&#xff0c…

安全隔离上网的有效途径:沙箱

在数字化浪潮日益汹涌的今天&#xff0c;网络安全成为了不可忽视的重要议题。沙箱技术作为一种高效的隔离机制&#xff0c;为企业和个人提供了一种在享受网络便利的同时&#xff0c;保障系统安全的解决方案。本文旨在深入探讨沙箱技术如何做到隔离上网&#xff0c;从而为用户提…

AI系统:未来科技的驱动力

引言 人工智能&#xff08;Artificial Intelligence, AI&#xff09;是一门研究如何使计算机模拟、延伸和扩展人类智能的学科。自20世纪50年代起&#xff0c;人工智能作为一项科学研究领域开始兴起。早期的AI系统主要集中在简单的任务&#xff0c;如棋类游戏和数学证明。随着计…

华为云物联网的使用

这里我们设置三个属性 1.温度DHT11_T 上传 2.湿度DHT11_H 上传 3.风扇motor 远程控制&#xff08;云平台控制设备端&#xff09; 发布主题&#xff1a; $oc/devices/{device_id}/sys/properties/report 发布主题时&#xff0c;需要上传数据&#xff0c;这个数据格式是JSON格式…

2007年上半年软件设计师【上午题】试题及答案

文章目录 2007年上半年软件设计师上午题--试题2007年上半年软件设计师上午题--答案2007年上半年软件设计师上午题–试题

公司管理系统

准备工作 上图mapper类型错了&#xff0c;不是class&#xff0c;是interface&#xff0c;修正过后的图片&#xff0c;如下所示 修正如下 spring.datasource.driver-class-namecom.mysql.cj.jdbc.Driver spring.datasource.urljdbc:mysql://localhost:3306/webm spring.datasour…

【Tech Point】

ARM加速LLama C 加速对象 LLama C 加速对象 LLama C 关键技术&#xff1a; 使用neon加速指令进行SIMD操作&#xff1b;优化数据排布&#xff0c;降低数据读取的中断