繁体   English   中英

带有线程 C# 的控制台 Writeline

[英]Console Writeline with threaded C#

您好,我正在尝试为我的控制台应用程序控制台输出制作线程系统。

我这样做了 KonsolStream。

public class KonsolStream
{
    ManualResetEvent _pauseEvent = new ManualResetEvent(true);
    ManualResetEvent _shutdownEvent = new ManualResetEvent(false);
    Thread _thread;

    private string _yazi;
    private int _tip;

    public int _Tip
    {
        get => _tip;
        set => _tip = value;
    }
    public string _Yazi
    {
        get => _yazi;
        set => _yazi = value;
    }

    public void KonsolaYaz()
    {
        switch (_Tip)
        {
            case 1:
                //uyarı
                Console.ForegroundColor = ConsoleColor.Red;
                Console.WriteLine(_Yazi);
                Console.ResetColor();
                IstemciDurdur();
                break;
            case 2:
                //başarı
                Console.ForegroundColor = ConsoleColor.Green;
                Console.WriteLine(_Yazi);
                Console.ResetColor();
                IstemciDurdur();
                break;
            case 3:
                //log
                Console.ForegroundColor = ConsoleColor.Yellow;
                Console.WriteLine(_Yazi);
                Console.ResetColor();
                IstemciDurdur();
                break;
            default:
                IstemciDurdur();
                break;
        }
    }
    private void IstemciDurdur()
    {
        _pauseEvent.Reset();
    }
    public void Start()
    {
        _thread = new Thread(DoWork);
        _thread.Start();
    }
    public void Resume()
    {
        _pauseEvent.Set();
    }

    public void DoWork()
    {
        while (true)
        {
            _pauseEvent.WaitOne(Timeout.Infinite);

            if (_shutdownEvent.WaitOne(0))
                break;

            KonsolaYaz();
        }
    }

}
public class KonsolMesaji : KonsolStream
{
    public KonsolMesaji(string yazi,int tip)
    {
        _Yazi = yazi;
        _Tip = tip;
    }
    public void Yaz()
    {
        Start();
    }
}

问题是当我启动 SistemBaslat() 消息不是同步的。 有时它以写消息开始。 有时它以再次开始,我想让 KonsolStream 像,当我想将一些输出写入控制台时,我将稍后使用此流。

如果您希望保留消息的顺序,则必须仅使用一个线程读取单个队列,并让所有其他线程将数据推入其中。 好消息是你的代码会简单得多; 坏消息是你必须在你想记录的任何地方访问队列(你可以创建一个静态记录器来缓解这个问题)。

编辑:我建议您检查此链接: Simple MultiThread Safe Log Class ,而不是给您代码。 你应该找到你所有的答案。

在阅读您的问题时,我在问自己:您只是出于学术原因(即了解多线程系统中的日志记录如何工作)而想了解这一点,还是真的希望在生产应用程序中使用多线程日志记录?以后?

如果您的答案是后者,我建议您使用log4net,因为这可以通过少量配置为您提供您想要的内容。

更新
再次查看问题后,我同意 PaulF 的观点,即仍然需要将线程的结果绑定在一起,然后将不同的桶按顺序写入控制台。 为了实现这一点,您可以使用一个类的(静态)实例来保存每个线程的所有日志消息(为了区分线程,您可以使用线程 ID 作为键)并等待线程完成,然后写入该线程的所有日志条目按顺序发送到控制台。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM