鸿蒙5.0项目开发——鸿蒙天气项目的实现(主页1)
【高心星出品】
文章目录
- 页面效果:
- 页面功能:
- 页面执行流程:
- 1. 页面初始化阶段
- 2. 定位获取阶段
- 3. 天气数据加载阶段
这个页面是整个天气应用的核心,集成了天气查询、定位、搜索等主要功能,提供了完整的天气信息服务。
页面效果:
页面功能:
1. 天气信息展示
-
当前天气信息:
-
城市名称
-
温度
-
天气状况
-
湿度
-
风速
-
PM2.5
-
空气质量
-
未来天气预报:
-
显示未来3天的天气
-
包含星期、天气类型、温度范围
2. 定位功能
-
自动定位:
-
请求定位权限
-
获取当前位置
-
根据位置获取城市信息
-
显示当前位置天气
3. 搜索功能
-
城市搜索:
-
搜索框输入城市名
-
实时搜索天气信息
-
保存搜索历史
4. 搜索历史管理
-
历史记录功能:
-
显示搜索历史列表
-
支持删除单条记录
-
支持清空所有历史
-
点击历史记录可快速查看天气
5. 界面交互
-
左侧抽屉菜单:
-
显示搜索历史
-
支持滑动关闭
-
编辑模式切换
-
删除历史记录
6. 加载状态
-
加载提示:
-
显示加载动画
-
错误提示对话框
-
操作结果提示
7. 数据管理
-
数据持久化:
-
保存搜索历史
-
缓存天气数据
-
管理城市信息
8. 错误处理
-
异常处理:
-
网络错误提示
-
定位失败处理
-
数据加载失败处理
页面执行流程:
1. 页面初始化阶段
-
页面加载时触发 aboutToAppear 生命周期
-
首先检查定位权限
-
如果有权限,直接开启定位
-
如果没有权限,向用户请求权限
-
用户同意后开启定位,拒绝则使用默认城市(南京市)
-
/*** 组件即将出现时的生命周期函数* @description * 1. 首先请求定位权限* 2. 获取当前位置信息*/async aboutToAppear(): Promise<void> {// 请求定位权限await this.locationpermission()// 获取当前位置信息this.getlocation()}
/*** 请求定位权限* @description * 1. 创建权限管理器实例* 2. 获取应用程序的accessTokenID* 3. 校验应用是否被授予定位权限* 4. 如果未授权,则请求用户授权* 5. 根据用户授权结果执行相应操作*/async locationpermission() {// 创建权限管理器实例let atManager: abilityAccessCtrl.AtManager = abilityAccessCtrl.createAtManager();// 初始化权限状态为拒绝let grantStatus: abilityAccessCtrl.GrantStatus = abilityAccessCtrl.GrantStatus.PERMISSION_DENIED;// 获取应用程序的accessTokenIDlet tokenId: number = 0;let bundleInfo: bundleManager.BundleInfo =await bundleManager.getBundleInfoForSelf(bundleManager.BundleFlag.GET_BUNDLE_INFO_WITH_APPLICATION);let appInfo: bundleManager.ApplicationInfo = bundleInfo.appInfo;tokenId = appInfo.accessTokenId;// 校验应用是否被授予定位权限grantStatus = await atManager.checkAccessToken(tokenId, 'ohos.permission.APPROXIMATELY_LOCATION');if (grantStatus == abilityAccessCtrl.GrantStatus.PERMISSION_DENIED) {// 如果未授权,请求用户授权atManager.requestPermissionsFromUser(this.context, ['ohos.permission.APPROXIMATELY_LOCATION']).then((data) => {let grantStatus: Array<number> = data.authResults;if (grantStatus[0] === 0) {// 用户同意授权,修改lcc值触发lc函数执行this.lcc = 2} else {// 用户拒绝授权,弹窗提示AlertDialog.show({message: '您已拒绝授权定位,无法体验当前位置天气的信息功能',title: '提示',confirm: {value: '确定', action: () => {}}})}}).catch((e: Error) => {// 授权过程发生错误console.error('gxxt 授权', e.message)})} else {// 已有权限,设置lcc=1this.lcc = 1}}
2. 定位获取阶段
-
检查系统定位是否开启
-
如果已开启,直接获取位置
-
如果未开启,请求用户开启定位
-
-
获取当前位置信息
-
根据位置信息获取城市名称
-
如果获取失败,使用默认城市
/*** 获取位置信息* @description 根据定位权限状态决定是否开启定位* - 如果lcc=1表示有定位权限,则开启定位* - 否则直接加载默认城市天气*/getlocation() {if (this.lcc == 1) {// 开启定位this.openlocation()} else {this.loadweather(this.cityName, false)}}/*** 开启定位功能* @description 检查并请求开启系统定位功能* 1. 首先检查定位功能是否已开启* 2. 如果未开启,则请求用户开启* 3. 开启成功后调用locationreq()获取位置* 4. 开启失败则提示用户* @throws 可能抛出定位相关错误*/openlocation() {try {// 检查定位功能是否开启let enable = geoLocationManager.isLocationEnabled()if (!enable) {// 创建权限管理器let atmanager = abilityAccessCtrl.createAtManager()// 请求开启定位功能atmanager.requestGlobalSwitch(this.context, abilityAccessCtrl.SwitchType.LOCATION).then((value) => {if (value) { // 开启定位成功this.locationreq()} else { // 开启定位失败AlertDialog.show({message: '定位开启失败', title: '提示', confirm: {value: '确定',action: () => {}}})}})} else {// 定位已开启,直接获取位置this.locationreq()}} catch (e) {console.error('gxxt location ', JSON.stringify(e))}}/*** 获取定位城市信息* @description 通过系统定位服务获取当前位置并解析城市名称* 1. 首先显示加载动画弹窗* 2. 配置定位请求参数,优先考虑定位速度,超时时间10秒* 3. 调用getCurrentLocation获取经纬度坐标* 4. 根据经纬度反向解析获取城市名称* 5. 成功获取城市名称后加载该城市天气* 6. 失败则加载默认城市天气*/locationreq() {// 显示加载动画弹窗this.opendialog()// 配置定位请求参数let request: geoLocationManager.SingleLocationRequest = {'locatingPriority': geoLocationManager.LocatingPriority.PRIORITY_LOCATING_SPEED,'locatingTimeoutMs': 10000}// 获取当前位置geoLocationManager.getCurrentLocation(request).then((result) => {// 配置反向地理编码请求参数let reverseGeocodeRequest: geoLocationManager.ReverseGeoCodeRequest ={ "latitude": result.latitude, "longitude": result.longitude, "maxItems": 1 };// 根据经纬度获取地址信息geoLocationManager.getAddressesFromLocation(reverseGeocodeRequest, (err, data) => {if (err) {// 获取城市名称失败console.log('gxxt getAddressesFromLocation err: ' + JSON.stringify(err));promptAction.showToast({ message: '获取城市名称失败,请连接网络!' })// 加载默认城市天气this.loadweather(this.cityName, false)} else {// 获取城市名称成功,加载该城市天气this.loadweather(data[0].locality as string, false)}});}).catch((error: BusinessError) => {// 定位失败处理console.error('gxxt , getCurrentLocation: error=' + JSON.stringify(error));promptAction.showToast({ message: '无法获取地理位置' })// 加载默认城市天气this.loadweather(this.cityName, false)});}
3. 天气数据加载阶段
-
根据城市名称查询城市编码
-
使用城市编码获取天气数据
-
更新界面显示:
-
当前天气信息(温度、天气状况等)
-
未来三天天气预报
-
空气质量等信息
-
-
如果是搜索操作,保存搜索历史
/*** 加载天气信息* @param cityname 城市名称* @param issearch 是否是搜索请求* @description 根据城市名称加载天气信息* 1. 首先根据城市名称查询城市编码* 2. 使用城市编码获取天气数据* 3. 如果不是搜索请求则关闭加载弹窗* 4. 如果是搜索请求则保存搜索历史* 5. 更新页面上的天气信息显示* 6. 包括:城市名、温度、天气描述、湿度、风速、PM2.5、空气质量* 7. 更新未来3天的天气预报信息*/private async loadweather(cityname: string, issearch: boolean) {let ad = new adcodedao(this.context)try {// 查询城市编码let code = await ad.querybyname(cityname)// 获取天气数据let weather = await getweather(code)if (!issearch) {// 非搜索请求,关闭加载弹窗this.closedialog()} else {// 搜索请求,保存搜索历史let sd = new searchdao(this.context)sd.insert({ keyword: cityname })}// 更新城市基本信息this.cityName = weather.cityInfo.citythis.temperature = weather.data.wenduthis.weatherDesc = weather.data.forecast[0].typethis.humidity = weather.data.shiduthis.windSpeed = weather.data.forecast[0].flthis.pm25 = weather.data.pm25 + ''this.quality = weather.data.quality// 更新未来3天天气预报this.day1week = weather.data.forecast[1].weekthis.day1type = weather.data.forecast[1].typethis.day1wendu = getwendu(weather.data.forecast[1].low, weather.data.forecast[1].high)this.day2week = weather.data.forecast[2].weekthis.day2type = weather.data.forecast[2].typethis.day2wendu = getwendu(weather.data.forecast[2].low, weather.data.forecast[2].high)this.day3week = weather.data.forecast[3].weekthis.day3type = weather.data.forecast[3].typethis.day3wendu = getwendu(weather.data.forecast[3].low, weather.data.forecast[3].high)} catch (e) {// 显示错误提示对话框AlertDialog.show({message: '该地区天气信息暂无法获取!', title: '提示', confirm: {value: '确定', action: () => {}}})}}
根据城市名称查询城市编码:
/*** 根据城市名称查询城市编码* @param name 城市名称* @returns 城市编码* @description * 1. 根据城市名称模糊查询数据库* 2. 只查询code字段* 3. 如果查询到结果则返回城市编码* 4. 如果查询失败则返回空字符串*/async querybyname(name: string) {let code: string = ''try {let rdb = await getrdb(this.context)let predicates = new relationalStore.RdbPredicates(TABLENAME)predicates.like('name', '%' + filter(name) + '%')let rs = await rdb.query(predicates, ['code'])if (rs.goToNextRow()) {code = rs.getString(rs.getColumnIndex('code'))}} catch (e) {console.error('gxxt adcodedao 查询失败: ', JSON.stringify(e))}return code}
使用城市编码获取天气数据
/*** 天气API的基础URL*/
export const BASEURL = 'http://t.weather.itboy.net/api/weather/city/'/*** 获取城市天气信息* @param citycode 城市编码* @returns Promise<weathermodel> 返回天气数据模型* @description * 1. 根据城市编码拼接完整的API URL* 2. 创建HTTP请求实例* 3. 配置请求头为JSON格式* 4. 发送GET请求获取天气数据* 5. 解析响应数据为weathermodel类型* 6. 如果状态码为200则返回数据* 7. 否则抛出错误* 8. 最后销毁HTTP请求实例*/
export function getweather(citycode: string) {let url = BASEURL + citycodelet req = http.createHttp()let opt: http.HttpRequestOptions = {header: {'Content-Type': 'application/json;charset=UTF-8'}}return new Promise<weathermodel>((resove, reject) => {req.request(url, opt).then((res) => {let data =JSON.parse( res.result as string) as weathermodelif(data.status==200) {resove(data)}else{reject('不在范围之内')}}).catch((e: Error) => {reject(e)}).finally(() => {req.destroy()})})}
相关文章:
鸿蒙5.0项目开发——鸿蒙天气项目的实现(主页1)
【高心星出品】 文章目录 页面效果:页面功能:页面执行流程:1. 页面初始化阶段2. 定位获取阶段3. 天气数据加载阶段 这个页面是整个天气应用的核心,集成了天气查询、定位、搜索等主要功能,提供了完整的天气信息服务。 …...
虚幻引擎5-Unreal Engine笔记之摄像机与场景捕获相关概念的解析
虚幻引擎5-Unreal Engine笔记之摄像机与场景捕获相关概念的解析 code review! 文章目录 虚幻引擎5-Unreal Engine笔记之摄像机与场景捕获相关概念的解析1. UE中SceneCapture和UCameraComponent的关系是什么?Camera和SceneCapture2D的关系是什么1.1 UCameraComponen…...
【vim】--- vim 插件说明 超详细持续更新中
在编程的艺术世界里,代码和灵感需要寻找到最佳的交融点,才能打造出令人为之惊叹的作品。而在这座秋知叶i博客的殿堂里,我们将共同追寻这种完美结合,为未来的世界留下属于我们的独特印记。【vim】--- vim 插件说明 超详细持续更新中 开发环境一、vim 插件管理器1、Vim-Plug2…...
医学影像系统的集成与工作流优化
🧑 博主简介:CSDN博客专家、CSDN平台优质创作者,高级开发工程师,数学专业,10年以上C/C++, C#, Java等多种编程语言开发经验,拥有高级工程师证书;擅长C/C++、C#等开发语言,熟悉Java常用开发技术,能熟练应用常用数据库SQL server,Oracle,mysql,postgresql等进行开发应用…...
Vue 和 React 状态管理的性能优化策略对比
一、Vue 状态管理优化策略 合理使用 Vuex 模块化 将全局状态拆分为模块,按需加载,避免单一 Store 文件过大。通过命名空间隔离状态,减少状态冗余和无效更新。 const moduleA { namespaced: true, state: { /* ... */ } }; const store new …...
python打包exe报错:处理文件时错误:Excel xlsx file; not supported
背景:最近用python写一个excel解析工具,然后打包成exe可执行文件的时候,遇到这样的问题 1.在我自己编译器运行是可以正常将上传后的excel进行解析,但是在打包成exe后,就无法正常解析excel 问题排查: 1.切换…...
libmemcached库api接口讲解一
前言:好多接口的用法都不怎么会,得学习一下具体的用法 memcached_st ✅ 一个连接 memcached 服务集群的“客户端实例”对象,用于管理连接、执行读写操作、设置行为、维护哈希环等一切功能。 它在使用中通常通过下面的方式创建: …...
【RabbitMQ】发布确认机制的具体实现
文章目录 模式介绍建立连接单独确认代码实现逻辑运行结果 批量确认代码实现逻辑运行结果 异步确认实现逻辑介绍代码实现逻辑运行结果 三种策略对比以及完整代码 模式介绍 作为消息中间件,都会面临消息丢失的问题,消息丢失大概分为三种情况: …...
RabbitMQ是什么?应用场景有哪些?
RabbitMQ 是一款开源的消息代理中间件,基于 AMQP(高级消息队列协议)实现,用于在分布式系统中进行异步通信和消息传递。它通过将消息的发送者和接收者解耦,提高了系统的可扩展性、可靠性和灵活性。 核心特点 多协议支持:不仅支持 AMQP,还兼容 STOMP、MQTT 等多种消息协议…...
数学实验(Matlab符号运算)
一、符号对象的建立 Matlab符号运算特点 计算以推理方式进行,因此不受计算误差积累所带来的困扰 符号计算指令的调用比较简单,与数学教科书上的公式相近 Matlab符号运算举例 符号对象与符号表达式 在进行符号运算时,必须先定义基本的符号…...
使用 hover-class 实现触摸态效果 - uni-app 教程
目录 一、什么是 hover-class 二、常用组件支持 hover-class 三、基本 效果说明: 四、配合 hover-start-time 和 hover-stay-time 五、注意事项 六、实践建议 在移动端开发中,良好的用户交互体验尤为重要,点击或长按某个按钮时&#x…...
# 深度剖析LLM的“大脑”:单层Transformer的思考模式探索
简单说一下哈 —— 咱们打算训练一个单层 Transformer 加上稀疏自编码器的小型百万参数大型语言模型(LLM),然后去调试它的思考过程,看看这个 LLM 的思考和人类思考到底有多像。 LLMs 是怎么思考的呢? 开源 LLM 出现之后…...
Git仓库迁移
前言 前面我讲了GitLab搭建与使用(SSH和Docker)两种方式,那么就会延伸出来一个情况:Git仓库迁移虽然这种情况很少发生,但是我自己公司近期要把 阿里云迁移到华为云,那么放在上面的Git仓库也要全量迁移下面我就写了一个脚本演示&am…...
Windows避坑部署CosyVoice多语言大语言模型
#工作记录 前言 在实际部署与应用过程中,项目的运行环境适配性对其稳定性与功能性的发挥至关重要。CosyVoice 项目虽具备强大的语音处理能力,但受限于开发与测试环境的侧重方向,其对运行环境存在特定要求。 该项目在 Linux 和 Docker 生态…...
《实现模式》以Golang视角解读 价值观和原则 day 1
为什么阅读实现模式? 为什么阅读《实现模式》?Kent Beck 的《实现模式》其核心思想——编写清晰、易于理解且易于维护的代码,对于软件工程的新手而言,直接深入复杂的设计模式或架构理念可能会感到困惑。《实现模式》则弥合了设计…...
解决 PicGo 上传 GitHub图床及Marp中Github图片编译常见难题指南
[目录] 0.行文概述 1.PicGo图片上传失败 2.*关于在Vscode中Marp图片的编译问题* 3.总结与启示行文概述 写作本文的动机是本人看到了Awesome Marp,发现使用 Markdown \texttt{Markdown} Markdown做PPT若加持一些 CSS , JavaScript \texttt{CSS},\texttt{JavaScript} …...
LeetCode 820 单词的压缩编码题解
LeetCode 820 单词的压缩编码题解 题目描述 题目链接 给定一个单词列表,将其编码为一个索引字符串S,格式为"单词1#单词2#…"。要求当某个单词是另一个单词的后缀时,该单词可以被省略。求最终编码字符串的最小长度。 解题思路 逆…...
Windows软件插件-写wav
下载本插件 本插件,将PCM音频流写入WAV音频文件。或将PCM音频流压缩为ALAW格式,写入WAV文件。可以创作大文件(超过4字节所能表示的大小)。插件类型为DLL,可以在win32和MFC程序中使用。使用本插件创建的ALAW格式WAV音频…...
基于 Spring Boot 瑞吉外卖系统开发(十五)
基于 Spring Boot 瑞吉外卖系统开发(十五) 前台用户登录 在登录页面输入验证码,单击“登录”按钮,页面会携带输入的手机号和验证码向“/user/login”发起请求。 定义UserMapper接口 Mapper public interface UserMapper exte…...
【Linux高级IO】多路转接之epoll
多路复用之epoll 一,认识epoll二,epoll的相关接口1. epoll_create2. epoll_ctl3. epoll_wait 三,epoll的原理四,epoll的两种工作模式(ET和LT)1. 两种工作模式2. 对比ET和LT 五,总结 在了解到sel…...
Java 性能调优全解析:从设计模式到 JVM 的 7 大核心方向实践
引言 在高并发、低延迟的技术场景中,Java 性能优化需要系统化的方法论支撑。本文基于7 大核心优化方向(复用优化、计算优化、结果集优化、资源冲突优化、算法优化、高效实现、JVM 优化),结合权威框架与真实案例,构建从…...
“海外滴滴”Uber的Arm迁移实录:重构大规模基础设施
云工作负载在性价比上的自然演进路径: Intel ➜ AMD ➜ ARM 不信?来看看 Uber 的做法: 01/Arm架构:云计算新时代 2023 年 2 月,Uber 正式开启了一项战略性迁移:将从本地数据中心迁移至云端,…...
java加强 -File
File类的对象可以代表文件/文件夹,并可以调用其提供的方法对象文件进行操作。 File对象既可以代表文件,也可以代表文件夹。 创建File对象,获取某个文件的信息 语法: File 对象名 new File("需要访问文件的绝对路径&…...
SQL注入 ---04
1 简单的sql注入 要求: 要有sql注入: 1,变量 2,变量要带入数据库进行查询 3,没有对变量进行过滤或者过滤不严谨 mysql> select * from users where id2 limit 0,1; 当我的语句这样写时查寻到的结果 当我修改为&…...
MySQL知识点总结(持续更新)
聚合函数通常用于对数据进行统计和聚合操作。以下是一些常见数据库系统(如 MySQL、PostgreSQL、Oracle、SQL Server 等)中常用的聚合函数: 常见的数据库聚合函数: COUNT():计算指定列中非空值的数量 SELECT COUNT(*) …...
数字信号处理-大实验1.1
MATLAB仿真实验目录 验证实验:常见离散信号产生和实现验证实验:离散系统的时域分析应用实验:语音信号的基音周期(频率)测定 目录 一、常见离散信号产生和实现 1.1 实验目的 1.2 实验要求与内容 1.3 实验…...
Qt操作SQLite数据库教程
Qt 中操作 SQLite 数据库的步骤如下: 1. 添加 SQLite 驱动并打开数据库 #include <QSqlDatabase> #include <QSqlError> #include <QSqlQuery>// 创建数据库连接 QSqlDatabase db QSqlDatabase::addDatabase("QSQLITE"); db.setData…...
【PSINS工具箱】基于工具箱的单独GNSS导航、单独INS导航、两者结合组合导航,三种导航的对比程序。附完整的代码
本文给出基于PSINS工具箱的单独GNSS导航、单独INS导航、两者结合组合导航(153EKF)的程序。并提供三者的轨迹对比、误差对比。 文章目录 运行结果MATLAB代码代码的简单介绍简介2. 平均绝对误差 (MAE)主要模块运行结果 三轴轨迹图: 各轴误差曲线: 命令行窗口的结果输出: …...
开发者的测试复盘:架构分层测试策略与工具链闭环设计实战
摘要 针对测试复盘流于形式、覆盖率虚高等行业痛点,本文提出一套结合架构分层与工具链闭环的解决方案: 分层测试策略精准化:通过单元测试精准狙击核心逻辑、契约测试驱动接口稳定性、黄金链路固化端到端场景,实现缺陷拦截率…...
手写CString类
学习和理解字符串处理机制:手写 CString 类是深入学习字符串处理和内存管理的有效方式。通过实现构造函数、析构函数、赋值运算符等,能够理解字符串在内存中的存储方式、动态内存分配和释放的原理,以及如何处理字符串的复制、拼接、查找等操作…...
electron结合vue,直接访问静态文件如何跳转访问路径
在最外的app.vue或者index.vue的js模块编写 let refdade ref(1);//刷新,获得请求// 获取完整的查询字符串(例如: "?dade/myms")const searchParams new URLSearchParams(window.location.search);// 获取 dade 参数的值…...
解读RTOS 第七篇 · 驱动框架与中间件集成
1. 引言 在面向生产环境的 RTOS 系统中,硬件驱动框架与中间件层是连接底层外设与上层应用的桥梁。一个模块化、可扩展的驱动框架能够简化外设管理,提升代码可维护性;而丰富的中间件生态则为网络通信、文件系统、图形界面、安全加密等功能提供开箱即用的支持。本章将从驱动模…...
Java GUI开发全攻略:Swing、JavaFX与AWT
Swing 界面开发 Swing 是 Java 中用于创建图形用户界面(GUI)的库。它提供了丰富的组件,如按钮、文本框、标签等。 import javax.swing.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener;public class SwingExa…...
Cursor 0.5版本发布,新功能介绍
Cursor,这款流行的AI编程平台,刚刚在其v0.50更新中推出了一系列新功能。 首先,请将您的Cursor IDE更新到最新版本。当您打开Cursor时,您应该会在屏幕左下方收到关于最新版本发布的通知。 更多上下文控制: 对上下文的精细可见性,以及最新模型的MAX模式。 聊天升级: 导出…...
Android学习总结之Glide自定义三级缓存(实战篇)
一、为什么需要三级缓存 内存缓存(Memory Cache) 内存缓存旨在快速显示刚浏览过的图片,例如在滑动列表时来回切换的图片。在 Glide 中,内存缓存使用 LruCache 算法(最近最少使用),能自动清理长…...
Maven 下载安装与配置教程
## 1. Maven 简介 Maven 是一个项目管理和构建自动化工具,主要用于 Java 项目。Maven 可以帮助开发者管理项目的构建、报告和文档,简化项目依赖管理。 ## 2. 下载 Maven 1. 访问 Maven 官方网站 [https://maven.apache.org/download.cgi](https://maven.…...
一篇解决Redis:持久化机制
目录 认识持久化 持久化方案 RDB(Redis DataBase) 手动触发 自动触发 小结 AOF(Append-Only File) AOF缓冲区刷新机制 AOF重写机制 AOF重写流程 编辑 混合持久化 认识持久化 我们都知道Mysql有四大特征,原子性,持久…...
使用IDEA创建Maven版本的web项目以及lombok的使用
1.新建项目 2.修改pom.xml 3.修改项目结构 4.在main/java下面写一个Servlet测试一下 然后当前页面往下滑 -Dfile.encodingUTF-8编写一句输出语句,测试是否成功部署配置,并选择到正确的位置: 回车以后 再回到idea里面,发现控…...
2025年AI开发者在开发者占比?
AI开发者在全球开发者中的占比目前没有一个统一且精确的数值,但根据行业报告和调研数据,可以给出以下大致的范围和趋势分析: 1. 综合估算范围 全球范围:AI/ML(机器学习)开发者约占开发者总数的 5%-15%&…...
SpringBoot整合MQTT实战:基于EMQX构建高可靠物联网通信,从零到一实现设备云端双向对话
一、引言 随着物联网(IoT)技术的快速发展,MQTT(Message Queuing Telemetry Transport)协议因其轻量级、低功耗和高效的特点,已成为物联网设备通信的事实标准。本文将详细介绍如何使用SpringBoot框架整合MQTT协议,基于开源MQTT代理EMQX实现设…...
Windows更新暂停七天关键注册表
环境:windows10 工具:procmon 下载地址:https://learn.microsoft.com/zh-cn/sysinternals/downloads/procmon 监控截图: 界面截图: 注: 1.北京时间差8小时 2.至少是从第二天恢复,即至少暂停…...
小白学习java第18天(上):spring
Spring :是一个轻量级(一个小依赖就可以实现还不是轻量级)的控制反转(IOC)和面向切面编程(AOP)的框架! 优点: 1.Spring 是一个开源免费的框架(容器…...
用Array.from实现创建一个1-100的数组
一、代码实现 let arr Array.from({length: 100}, (_, i) > i 1); 二、代码分析 1、Array.from(arrayLike, mapFn) (1)arrayLike 类数组对象(如 { length: 100 })本身没有索引属性(如 0: undefined, 1: undefi…...
什么是物联网 IoT 平台?
目录 物联网IoT平台的定义 物联网 IoT 平台发展历程 物联网IoT平台数据的特征 物联网IoT平台的处理流程 专为物联网 IoT 平台处理而生的时序数据库 物联网 IoT 平台时序数据处理面临的挑战及解决方案 收益与价值 物联网 IoT 平台企业案例 至数摇光 x TDengine 华自科技…...
PostgREST:无需后端 快速构建RESTful API服务
在现代 Web 开发中,API 已成为连接前后端的核心桥梁,传统的做法是通过后端框架来构建API接口,然后由前后端人员进行联调。 PostgREST是基于无服务器的一种实现方案,允许开发者将PostgreSQL数据库直接暴露为RESTful API࿰…...
3天北京旅游规划
北京 第一天应该集中在故宫和市中心区域,比如天安门、人民广场。这样可以体验到北京的历史和政治文化。午餐推荐烤鸭,因为这可是北京的特色。下午可以安排南锣鼓巷,既有古色古香的胡同,又有丰富的美食选择。 第二天的话࿰…...
MySQL--day1--数据库概述
(以下内容全部来自上述课程) 概述 1. 为什么要用数据库 持久化:内存中的数据断电之后就不存在了,所以需要持久化–>需要相关介质。 其中的一个介质就是数据库:存储数据量大、存储数据类型多 2. 数据库与数据库…...
[思维模式-38]:看透事物的关系:什么是事物的关系?事物之间的关系的种类?什么是因果关系?如何通过数学的方式表达因果关系?
一、什么是事物的关系? 事物的关系是指不同事物之间存在的各种联系和相互作用,它反映了事物之间的相互依存、相互影响、相互制约等特性。以下从不同维度为你详细阐述: 1、关系的类型 因果关系 定义:一个事件(原因&a…...
图像识别与 OCR 应用实践
图像识别是一种让计算机具备“看”与“理解”图像能力的人工智能技术,其目标是从图像或视频中提取有意义的信息,如物体、人物、场景或文字。在现实生活中,这项技术被广泛应用于面部识别、自动驾驶、安防监控、医疗诊断、图像搜索等多个领域。…...
深入理解卷积神经网络:从基础原理到实战应用
在人工智能领域,卷积神经网络(Convolutional Neural Network,简称 CNN)凭借其强大的图像识别、处理能力,成为深度学习中不可或缺的技术。无论是自动驾驶汽车识别道路标志,还是医学影像分析辅助疾病诊断&…...