【Delphi】 各个平台使用 ntfy 效果说明

目录

[一、Delphi 中使用 ntfy 库下载地址](#一、Delphi 中使用 ntfy 库下载地址)

二、各个平台使用效果说明

[1. android 平台](#1. android 平台)

[2. ios 平台](#2. ios 平台)

[3. windows 平台](#3. windows 平台)

三、总结


一、Delphi 中使用 ntfy 库下载地址

二、各个平台使用效果说明

约定:

ntfy 既可以订阅消息,也可以发布消息。我们约定订阅消息和发布消息在同一个程序中,例如对于windows来说,就是一个EXE程序,对于android来说就是一个apk文件。

1. android 平台

  1. 发布消息和订阅消息函数如果都在主进程中运行,则启动订阅功能后,如果调用发布消息,则会导致程序卡死;改进的方法是将订阅消息在主进程中执行,但是发布消息通过线程任务来执行!
  2. 程序进入后台,然后重新前台后,订阅和发布消息功能都正常;
  3. 如果收到了订阅消息,此时立即发布消息(测试在40秒内),发布消息会正常发布成功,但是订阅消息会把刚刚收到的订阅消息在触发收到一次,这是不是期望的结果,需要进行处理。处理的方法是,每隔消息都有Id,如果收到的小时的Id就是上一条消息的Id,就不用处理,说明是重复收取。

2. ios 平台

  1. 发布消息和订阅消息函数如果都在主进程中运行,则启动订阅功能后,如果调用发布消息,不会导致程序卡死;
  2. 程序进入后台,然后重新前台后,订阅将会失效,发布消息功能正常;
  3. 如果收到了订阅消息,此时立即发布消息(测试在40秒内),发布消息会正常发布成功,但是订阅消息会把刚刚收到的订阅消息在触发收到一次,这是不是期望的结果,需要进行处理。处理的方法是,每隔消息都有Id,如果收到的小时的Id就是上一条消息的Id,就不用处理,说明是重复收取。

3. windows 平台

  1. 发布消息和订阅消息函数如果都在主进程中运行,则启动订阅功能后,如果调用发布消息,不会导致程序卡死;
  2. windows系统休眠后,然后重新启动后,订阅将会失效,发布消息功能正常;
  3. 如果收到了订阅消息,此时立即发布消息(测试在40秒内),发布消息会正常发布成功,但是订阅消息会把刚刚收到的订阅消息在触发收到一次,这是不是期望的结果,需要进行处理。处理的方法是,每隔消息都有Id,如果收到的小时的Id就是上一条消息的Id,就不用处理,说明是重复收取。

三、总结

|----|--------------|--------------|--------------|---------------|
| 序号 | 平台 | 发布订阅同一程序 | 前台 - 后台 - 前台 | 40秒内会重复收到订阅消息 |
| 1 | android | 异常(卡死) | 正常 | 会收到重复消息 |
| 2 | ios | 正常 | 异常 | 会收到重复消息 |
| 3 | windowindows | 正常 | 异常 | 会收到重复消息 |

处理方法:

:将发布消息函数放置在线程中;

:监测ios程序从前台到后台以及从后台到前台的变化事件,监测Windows程序从休眠到启动该以及从启动到休眠的变化事件,在变化事件中重新订阅消息;

:对于订阅事件中根据消息Id,过滤掉重复的消息;

程序APP_BOX中使用!

相关推荐
黑子Kuroko17 天前
写一个 EventBus 实现微信小程序的发布订阅,支持全局消息通知、跨页面通信,高效好用!
微信小程序·eventbus·消息订阅·消息发布订阅·跨页面
左边的天堂3 个月前
Mqtt消费端实现的几种方式
mqtt·消息订阅·mqtt server·mqtt broken
放羊的牧码1 年前
Redis - 订阅发布替换 Etcd 解决方案
数据库·redis·mysql·etcd·订阅发布·消息订阅·消息监听