鸿蒙子系统解读-分布式软总线子系统初步研究(下)

本文深入解析鸿蒙系统中分布式软总线子系统的数据传输过程,包括CreateSessionServer()函数的实现、会话创建、数据接收与处理等关键环节,详细阐述了软总线如何进行会话管理和数据传输。
摘要由CSDN通过智能技术生成

鸿蒙子系统解读-分布式软总线子系统初步研究(下)

本文作者:江苏润和软件股份有限公司 郎建中

3.2. 数据传输

上一节我们看了PublishService()函数的代码实现过程。被发现端发布服务后,软总线回调发布成功的函数中,被发现端需要使用CreateSessionServer()来创建会话的服务器等待发现端的连接创建会话。下面我们就来分析CreateSessionServer()函数的实现过程。

数据传输部分的代码位于foundation/communication/services/softbus_lite/trans_service目录中。其目录结构如下:

在这里插入图片描述

CreateSessionServer()函数的实现就在tcp_session_manager.c中。我们看看这个函数的代码实现:

在这里插入图片描述

SoftBusCheckPermission()前面有介绍过,就是检查权限。

GetTcpMgrLock()和ReleaseTcpMgrLock()就是通过g_sessionManagerLock这个Mutex进行互斥操作,防止同一时间多个模块同时在创建Session Server。

真正的业务逻辑在CreateSessionServerInner()函数中,我们来看看代码:

  • 1
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值