Linux源码阅读笔记13-进程通信组件上

简介: Linux源码阅读笔记13-进程通信组件上

Linux进程通信方式

  • 管道:创建的时候分配一个页大小内存,空间有限,不适合大量数据传输。
  • 消息队列:有两次copy造成额外的CPU消耗,不适合大量信息传输,效率比较低。
  • 共享内存:多个进程共享一块内存,没有同步机制,需要自己实现同步机制。
  • 套接字:在单机的情况下面走网络传输效率低。
  • 信号量:是一种锁机制,方式多个进程访问同一个资源,是一种同步手段。
  • 信号:不适合数据传输。

Android会什么会实现IPC Binder机制

  • 耦合性:C/S架构,不是网络通信,而是Binder机制。C和S是独立的。
  • 安全角度:Android是开放操作系统,保护每一个进程之间信息的安全。
  • 开发角度:在IPC中是C和C++,安卓使用Java,对组件进行Java的封装。

如何自己开发一个内核模块

make # 编译出模块
insmod xxx.ko # 将模块插入内核
lsmod # 查看模块
mknod /dev/mychannel c 96 0 # 创建设备文件 字符模块 主设备号 次设备号
# 启动进程

模块开发

什么是主次设备号

每一个设备都有一个设备号,字符模块有一个字符模块的ID就是设备号;一个主设备号可以有多多个次设备号

private_data

设备文件的私有空间,可以被poll感知到。

insmod时候调用Init

  1. 注册设备
  2. 初始化设备
  3. 添加到内核
  4. 初始化private_data

channel_open

  1. 检查设备是否对应
  2. 将分配好的空间指向private_data

channel_read

  1. 有数据时读取对应长度的数据
  2. 没有数据等待数据写入唤醒

channel_write

  1. 通过最大长度判断数据是否可以写入private_data
  2. 写入数据唤醒io多路复用的read(channel_read)

channel_poll

  1. 初始化
  2. 控制标志位
相关文章
|
10天前
|
消息中间件 Linux
Linux中的System V通信标准--共享内存、消息队列以及信号量
希望本文能帮助您更好地理解和应用System V IPC机制,构建高效的Linux应用程序。
78 48
|
7天前
|
消息中间件 Linux C++
c++ linux通过实现独立进程之间的通信和传递字符串 demo
的进程间通信机制,适用于父子进程之间的数据传输。希望本文能帮助您更好地理解和应用Linux管道,提升开发效率。 在实际开发中,除了管道,还可以根据具体需求选择消息队列、共享内存、套接字等其他进程间通信方
39 16
|
3月前
|
存储 Unix Linux
进程间通信方式-----管道通信
【10月更文挑战第29天】管道通信是一种重要的进程间通信机制,它为进程间的数据传输和同步提供了一种简单有效的方法。通过合理地使用管道通信,可以实现不同进程之间的协作,提高系统的整体性能和效率。
|
3月前
|
消息中间件 存储 供应链
进程间通信方式-----消息队列通信
【10月更文挑战第29天】消息队列通信是一种强大而灵活的进程间通信机制,它通过异步通信、解耦和缓冲等特性,为分布式系统和多进程应用提供了高效的通信方式。在实际应用中,需要根据具体的需求和场景,合理地选择和使用消息队列,以充分发挥其优势,同时注意其可能带来的复杂性和性能开销等问题。
|
4月前
|
网络协议 Linux 网络性能优化
Linux C/C++之TCP / UDP通信
这篇文章详细介绍了Linux下C/C++语言实现TCP和UDP通信的方法,包括网络基础、通信模型、编程示例以及TCP和UDP的优缺点比较。
100 0
Linux C/C++之TCP / UDP通信
|
4月前
|
网络协议 Linux
linux学习之套接字通信
Linux中的套接字通信是网络编程的核心,允许多个进程通过网络交换数据。套接字提供跨网络通信能力,涵盖本地进程间通信及远程通信。主要基于TCP和UDP两种模型:TCP面向连接且可靠,适用于文件传输等高可靠性需求;UDP无连接且速度快,适合实时音视频通信等低延迟场景。通过创建、绑定、监听及读写操作,可以在Linux环境下轻松实现这两种通信模型。
68 1
|
4月前
|
存储 Python
Python中的多进程通信实践指南
Python中的多进程通信实践指南
51 0
|
5月前
|
Java Android开发 数据安全/隐私保护
Android中多进程通信有几种方式?需要注意哪些问题?
本文介绍了Android中的多进程通信(IPC),探讨了IPC的重要性及其实现方式,如Intent、Binder、AIDL等,并通过一个使用Binder机制的示例详细说明了其实现过程。
481 4
|
6月前
|
关系型数据库 Java Linux
在Linux中,有哪些基本组件?
在Linux中,有哪些基本组件?
|
6月前
|
Linux 开发者
Linux源码阅读笔记18-插入模型及删除模块操作
Linux源码阅读笔记18-插入模型及删除模块操作

热门文章

最新文章