有时,当我执行上面的语句时,程序在控制台应用程序中冻结。如果我中断了,我就不能移动到下一行。我需要重置一个缓冲区还是什么?
这是一个在屏幕上显示消息的批处理应用程序。有没有人经历过这种情况,并设法解决了它。这似乎是一个新事物。我使用的是Visual Studio 2017专业版。
WriteLine停止的函数如下所示。sMessage的值为空"“。
static void Display(string sMessage, DisplayColours eColour = DisplayColours.White)
{
if (eColour == DisplayColours.Yellow)
Console.ForegroundColor = ConsoleColor.Yellow;
if (eColour == DisplayColours.Blue)
Console.ForegroundColor = ConsoleColor.Cyan;
if (eColour == DisplayColours.Green)
Console.ForegroundColor = ConsoleColor.Green;
if (eColour == DisplayColours.Red)
Console.ForegroundColor = ConsoleColor.Red;
if (eColour == DisplayColours.Magenta)
Console.ForegroundColor = ConsoleColor.Magenta;
if (oFptr != null)
{
oFptr.WriteLine(sMessage);
oFptr.Flush();
}
Console.WriteLine(sMessage);
Console.ForegroundColor = ConsoleColor.White;
}发布于 2017-08-26 21:02:31
可能导致这种情况的一件事是,如果您在控制台窗口上单击,使其开始选择文本,换句话说,这是将文本复制出控制台窗口的第一步。发生这种情况时,对控制台窗口的写入将挂起,直到您返回控制台窗口并按Enter键删除选择框。
发布于 2017-07-24 16:35:41
它也碰巧是,甚至有时当我调试我的代码时,它也没有启动(只是冻结了)。有时我需要停止执行并重新调试我的代码。我删除了visual studio并重新安装,现在一切都很好。我建议你也这样做。
发布于 2018-07-13 19:07:40
通过使用System.Threading.Tasks.Dataflow nuget包,您可以在用户选择控制台窗口上的文本时使用缓冲区来帮助避免锁定应用程序
private static BufferBlock<string> _buffer = new BufferBlock<string>();
private static Task _consumer;
private static CancellationTokenSource _cts;
public static void Main(string[] args)
{
_buffer = new BufferBlock<string>();
_cts = new CancellationTokenSource();
_consumer = ConsumeAsync(_buffer, _cts.Token);
for (int i = 0; i < 100000; i++)
{
WriteToConsole(i.ToString());
}
Console.ReadLine();
}
private static void WriteToConsole(string message)
{
SendToBuffer(_buffer, message);
}
private static void SendToBuffer(ITargetBlock<string> target, string message)
{
target.Post(message);
}
private static async Task ConsumeAsync(IReceivableSourceBlock<string> source, CancellationToken cancellationToken)
{
while (await source.OutputAvailableAsync(cancellationToken))
{
var message = await source.ReceiveAsync();
Console.WriteLine(message);
}
}这意味着对控制台的写操作根本不会阻塞,所以它在很多情况下可能没有用处。在我的例子中,我只需要输出日志信息
https://stackoverflow.com/questions/45275480
复制相似问题