java c 通信_Java和C / C ++之间进程间通信的最快(低延迟)方法

刚刚在我的Corei5 2.8GHz上测试了Java的延迟,只发送/接收单字节,2个Java进程刚刚生成,没有为任务集分配特定的CPU核心:

TCP - 25 microseconds

Named pipes - 15 microseconds

现在显式指定核心掩码,如taskset 1 java Srv或taskset 2 java Cli:

TCP, same cores: 30 microseconds

TCP, explicit different cores: 22 microseconds

Named pipes, same core: 4-5 microseconds !!!!

Named pipes, taskset different cores: 7-8 microseconds !!!!

所以

TCP overhead is visible

scheduling overhead (or core caches?) is also the culprit

同时Thread.sleep(0)(作为strace显示导致执行单个sched_yield()Linux内核调用)需要0.3微秒 - 因此命名为单核的命名管道仍然有很多开销

一些共享内存测量:    2009年9月14日 - Solace Systems今天宣布其统一消息平台API使用共享内存传输可以实现小于700纳秒的平均延迟。   [http://solacesystems.com/news/fastest-ipc-messaging/]

附: - 第二天尝试以内存映射文件的形式共享内存,如果忙碌等待是可以接受的,我们可以将延迟减少到0.3微秒使用如下代码传递单个字节:

MappedByteBuffer mem =

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值