Я работаю с NamedPipeServerStream для связи между двумя процессами. Вот код, в котором я инициализирую и подключаю канал:
void Foo(IHasData objectProvider)
{
Stream stream = objectProvider.GetData();
if (stream.Length > 0)
{
using (NamedPipeServerStream pipeServer = new NamedPipeServerStream("VisualizerPipe", PipeDirection.Out, 1, PipeTransmissionMode.Byte, PipeOptions.Asynchronous))
{
string currentDirectory = Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location);
string uiFileName = Path.Combine(currentDirectory, "VisualizerUIApplication.exe");
Process.Start(uiFileName);
if(pipeServer.BeginWaitForConnection(PipeConnected, this).AsyncWaitHandle.WaitOne(5000))
{
while (stream.CanRead)
{
pipeServer.WriteByte((byte)stream.ReadByte());
}
}
else
{
throw new TimeoutException("Pipe connection to UI process timed out.");
}
}
}
}
private void PipeConnected(IAsyncResult e)
{
}
Но он, похоже, не ждет. Я постоянно получаю следующее исключение:
System.InvalidOperationException: Труба еще не подключена. в System.IO.Pipes.PipeStream.CheckWriteOperations() в System.IO.Pipes.PipeStream.WriteByte(значение байта) в PeachesObjectVisualizer.Visualizer.Show(IDialogVisualizerService windowService, IVisualizerObjectProvider objectProvider)
Я бы подумал, что после ожидания ожидания все должно быть готово к работе.
Если я использую pipeServer.WaitForConnection(), все работает нормально, но зависание приложения, если канал не подключается, не является опцией.
Вам нужно позвонить EndWaitForConnection.
var asyncResult = pipeServer.BeginWaitForConnection(PipeConnected, this);
if (asyncResult.AsyncWaitHandle.WaitOne(5000))
{
pipeServer.EndWaitForConnection(asyncResult);
// ...
}
Смотрите: шаблон проектирования IAsyncResult.