QQ 大一统 NT 架构,腾讯开发者介绍技术架构升级变迁史

2024-05-16 12:26IT之家 - 沛霖(实习)
感谢IT之家网友 花生麻吉 的线索投递!

IT之家 5 月 16 日消息,2023 年 6 月 27 日,手机 QQ 安卓 8.9.63 / iOS 8.9.65 发布,这是手机 QQ 首个基于 NT 架构的正式版,2023 年 7 月 3 日,NT 架构 Windows QQ 上架官网,跨平台三端重构正式统一。腾讯开发者何金源今日发文,介绍了手机 QQ 技术架构升级背后的技术故事。

2020 年,QQ 开发团队开始着手做架构升级。鉴于手机 QQ 的业务复杂度、代码量级都非常大,于是他们采用分阶段逐步演进的策略去进行架构升级。

手机 QQ 新架构按业务划分模块,业务模块之间相互解耦,通过接口和路由进行通信。同时按层级设计划分,层级自上而下依赖,上层模块可依赖下层模块,但下层模块不能逆向依赖上层模块。

由于 QQ 不同平台客户端各自发展,代码复用率极低,开发和维护成本过高,还导致了多端体验不一致、端内业务体验参差不齐等问题,开发团队决定推进手机 QQ NT 架构升级项目

为了实现架构升级和统一,项目团队先用 C++ 开发了具备 QQ IM 核心功能的跨平台内核层:把 IM 核心业务逻辑(IT之家注:好友、群、频道等消息逻辑、资料与关系链逻辑、图片语音视频等富媒体收发逻辑、实时音视频逻辑等),QQ 通用组件,以及线程 / 网络 / IO 等通用资源管理模块和操作系统封装部分,由原来的各平台原生语言实现,统一下沉到 C++ 跨平台层

▲ NT 内核层采用 C++ 跨平台内核

为了控制项目质量风险,NT 跨平台内核先接入用户量相对较少,对功能补齐紧迫度高的桌面端,完全用新架构重写桌面端。在桌面端完成功能验证和质量测试之后,开始向移动端迁移,并顺利完成了 iOS 和安卓平台的集成。

开发团队基于重构后的架构,对性能进行全面优化。以聊天窗口(AIO)为例,基于全新数据流架构 + 数据预加载 + UI 逻辑并行化的设计思路,完成单向数据流驱动与异步加载渲染,系统资源全力供给 AIO 消息列表,最终性能指标提升明显,AIO 内查看、跳转、滑动消息“顺畅丝滑”。其它 QQ 主场景,如消息列表页、消息与富媒体收发、图片视频查看等,也采用相同的路径进行优化,最终性能全面提升。

广告声明:文内含有的对外跳转链接(包括不限于超链接、二维码、口令等形式),用于传递更多信息,节省甄选时间,结果仅供参考,IT之家所有文章均包含本声明。

文章价值:
人打分
有价值还可以无价值
置顶评论
    热门评论
      文章发布时间太久,仅显示热门评论
      全部评论
      请登录后查看评论
        取消发送
        软媒旗下人气应用

        如点击保存海报无效,请长按图片进行保存分享