gpt4 book ai didi

c# - node js中的Windows命名管道(首选共享内存)

转载 作者:可可西里 更新时间:2023-11-01 09:32:42 27 4
gpt4 key购买 nike

我正在使用命名管道在 Windows 中的 2 个进程之间共享一些数据。一个是 Node 进程,另一个是 C# 进程。这是我在我的 Node 进程中使用的代码示例:

var net = require('net');

var PIPE_NAME = "mypipe";
var PIPE_PATH = "\\\\.\\pipe\\" + PIPE_NAME;

var L = console.log;

var server = net.createServer(function(stream) {
L('Server: on connection')

stream.on('data', function(c) {
L('Server: on data:', c.toString());
});

stream.on('end', function() {
L('Server: on end')
server.close();
});

stream.write('Take it easy!');
});

server.on('close',function(){
L('Server: on close');
})

server.listen(PIPE_PATH,function(){
L('Server: on listening');
})

我在 C# 中使用 NamedPipeClientStream 来读取数据。我在两侧循环执行此操作,例如我的 Node 进程是生产者,C# 进程是消费者。

这很好用。

但有时 C# 循环会挂起,此时在我的 Node 进程中我想用新数据覆盖旧数据。我想知道我是否可以在我的管道(我在 nodejs 中创建的管道)中指定一些最大大小或数据超时但在标准文档中找不到这样的东西。

如果不能通过这种方式解决,有一个共享内存路径可以解决问题,但我找不到任何稳定的 nodejs 共享内存库,它在 windows 上运行良好(而且我没有太多时间写现在一个)。我需要一些指示才能朝着正确的方向前进。

欢迎任何建议。谢谢。

编辑:我真的很想使用共享内存实现上述内容,因为我需要快速共享大量数据并且我需要调整性能。关于如何实现它的任何指示?

最佳答案

根据我的要求,我想出了一种在 nodejs 的可写流中使用 drain 事件的方法。

关于c# - node js中的Windows命名管道(首选共享内存),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43350129/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com