面试官:进程通信方式有哪些?我被问倒了!

面试官:看你简历上写了不少多线程、分布式相关的项目,我们来聊聊进程通信吧。你知道进程之间有哪些通信方式吗?

:进程通信?这个...我只记得管道和共享内存,其他的有点模糊了... alt

解析答案

进程通信基础概念

进程通信(IPC,Inter-Process Communication)是指在不同进程之间传播或交换信息的技术。由于每个进程都有自己独立的地址空间,一个进程不能直接访问另一个进程的变量和数据结构,所以操作系统必须提供专门的机制来实现进程间的通信。

主要通信方式详解

1. 管道(Pipes)

管道是最古老的进程通信方式之一,它本质是一个内核缓冲区,提供单向通信能力。

特点:

  • 单向通信,一端写,一端读
  • 只能用于有亲缘关系的进程(如父子进程)
  • 数据以字节流形式传输
  • 容量有限,写满时写进程阻塞

Java示例:

// 创建管道流
PipedInputStream pis = new PipedInputStream();
PipedOutputStream pos = new PipedOutputStream(pis);

// 写线程
new Thread(() -> {
    try {
        pos.write("Hello Pipe!".getBytes());
        pos.close();
    } catch (IOException e) {
        e.printStackTrace();
    }
}).start();

// 读线程  
new Thread(() -> {
    try {
        int data;
        while ((data = pis.read()) != -1) {
            System.out.print((char) data);
        }
        pis.close();
    } catch (IOException e) {
        e.printStackTrace();
    }
}).start();

2. 命名管道(Named Pipes)

命名管道解决了普通管道只能在亲缘进程间通信的限制,通过文件系统中的特殊文件实现。

特点:

  • 有名称,可在文件系统中看到
  • 允许无亲缘关系的进程通信
  • 支持双向通信(某些系统)
  • 通信前需要显式打开

3. 消息队列

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

大学四年面经(学院本) 文章被收录于专栏

大学全部面经从大一到大四,从实习、秋招、春招等等,各种岗位,中小厂,乃至大厂面经! 公粽号:程序员落叶,里面分享全部文章详情。

全部评论

相关推荐

10-30 15:05
门头沟学院 Java
美团 后段开发 23k*15.5 硕士985
牛丫丫丫:你该不会是美团的hr吧
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
昨天 13:31
现在是2025年10月27日,由于焦虑无法入睡,有感而发写下了这段文字。回想过去三年(甚至可以说是过去的21年),自己一直都是一个不断自我打碎自我重组自我妥协的过程,面对大的困难大的打击,总是会影响自己的心态,在这个过程中不断的去降低预期,安慰自己说是在保护自己,实际上是不敢对自己抱有太大的希望。高考以一个差强人意的分数考上了985,虽然说知道自己数学考的差的不行(两位数),但是当成绩出现之后仍是惊喜到狂叫。每次回想自己的曾经的成果,都有一种恍惚感,感觉自己努力了,但是却又总觉得差那么一口气,总结一下应该就是差那点心气。但是我也如愿的考上了大家口中的好学校,来了之后成绩也还凑合,但是就是无法保研,专业分流之后更是保研无望,在那之后就开始准备找工作了。但是自己的规划能力又极差无比,根本不知道找工作需要什么技能,记得大二的当时刷了很多力扣,学了很多408,直到大二下才迷途知返,知道自己没努力到正确的方向,开始跟着黑马学java,做了外卖点评,在今年的一月份才成功做完了项目,可是当时一点八股都没有学,也花了两个月速成了八股,在三月份开始投递暑期实习简历。这就是噩梦的开始,在这个过程中我的心气也在不断的消亡,由于学历我还是能获得面试机会的,但是几场面试就将我打回原形,基础不牢项目不好没有实习,各个差的标签打在身上令我羞耻难当,经过几次面试的打击使得我逃避了一段时间,用要准备期中考不想挂科的借口,让自己逃离找实习一段时间。但是五月份之后又开始找实习了(回到现实了),发现已经没什么公司招实习生了,那段时间经常失眠,感叹自己浪费了自己的学历以及过去十几年的努力(心气还是太高了哈哈),觉得自己规划能力好差。但是还是非常感谢华为在最后能给予我一段实习经历,尽管我不优秀,跟同部门实习生的学历越差了十万八千里,但是还是非常感谢收留我(不管大家对他评价如何,我都是非常感激的)。实习对我来说就是一段缓冲期,我仿佛在象牙塔一般。那段日子我身上没有求职的焦虑,虽然说每天也很忙,工作的时候要赶需求,下班之后做项目背八卦刷力扣,但是生活还是充实且规律的,我不再被焦虑所包裹,是这一年里我最快乐的一段日子。九月份回来秋招之后,深感秋招之艰难,可能是因为投的晚,实习产出有限,水平不足,在这段时间不断碰壁,几乎没有什么面试的机会,直到如今也没有任何一个offer。但是每天还是坚持在图书馆学习,近期真的有点泄气了,经历上周十场面试,已燃尽,但是给我带来了一丝希望,已有两家公司进了池子,且有两家公司还在流程中,但是我不敢抱有希望,很怕希望破碎使得我再次破碎,但是心里又渴望那希望。打完这段话准备休息了,焦虑没用但是无法不焦虑,感觉自己能力虽然说不是非常强但是应该也不算特别差吧,但是仍如此艰难,可能不仅仅是自己能力的原因吧,时运,机遇都需要合适。将这段文字写下也不是为了传播焦虑输出我的坏情绪,也是希望看到这段话且能共情我的人,看到这些心里可以好受一些,肯定不止我一个人深陷焦虑中,希望这些心里话能给大家带来一丝安慰!(这算比惨吗不算吧哈哈哈,毕竟我从bg上还是看得过去的吧,但是也是0offer,想想我应该会宽慰一点)-------------分割线-------------2025/10/31 今天拿到了第一个满意的意向,那就暂时休息一下吧,祝所有人如愿。
点赞 评论 收藏
分享
昨天 21:01
武汉大学 Java
lulululula...:仅仅按我个人的经历来看,大厂其实很少特别关注微服务,一般对微服务架构,限流熔断降级的概念了解就行,简历不写也不容易被问到。现在这个势头不如站点agent应用,比如做做mcp,rag,r对话agent,记忆管理之类的,说不定可以蹭上一波热度,进公司虽然可能还是干agent的杂活,但是可以学一学组内的业务和技术了
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务