为什么Console.WriteLine()在Stream.ReadAsync()的回调中阻塞?

时间:2013-08-23 15:37:45

标签: c# io console

我有一个回调函数,我试图在重写的ReadAsync()中写入我读取的数据。

private void StreamCallback(byte[] bytes)
{
    Console.WriteLine("--> " + Encoding.UTF8.GetString(bytes)); // the whole application is blocked here, why?
    if (OnDataReceived != null)
    {
        string data = Encoding.UTF8.GetString(bytes);
        OnDataReceived(data);
    }
}

重写的ReadAsync()如下所示。

public override async Task<int> ReadAsync(byte[] buffer, int offset, int count, System.Threading.CancellationToken cancellationToken)
{
    var read = await _originalStream.ReadAsync(buffer, offset, count, cancellationToken);
    _readCallback(buffer);

     return read;
}

我真正想要实现的是在XmlReader解析之前监视网络流。这与我的其他问题有关&gt; Reading from same SslStream simultaneously?&lt;。{我该怎么办?

更新

实际上Encoding.UTF8.GetString(bytes)阻止了应用程序。为了使问题更加完整,我列出了读取XML流的代码。

using (XmlReader r = XmlReader.Create(sslStream, new XmlReaderSettings() { Async = true }))                
{
    while (await r.ReadAsync())
    {
        switch (r.NodeType)
        {
            case XmlNodeType.XmlDeclaration:
                ...
                break;
            case XmlNodeType.Element:
...

1 个答案:

答案 0 :(得分:1)

根据您发布的代码,StreamCallback()将阻塞,直到该流结束。您将一个字节指针传递给Encoding.UTF8.GetString(bytes);因此,它需要保持查询字节,直到它到达结尾。它将永远不会到达结尾,因为字节来自流,直到该流关闭。

您需要一次处理您的流一定数量的字节,或者直到看到某个字符。