Con*_*ngo 5 .net c# .net-4.0 visual-studio c#-4.0
我有一个控制台程序,我想不断将Console.Write的结果镜像到一个集合,我可以实时查看它的尾部.集合可以是数组,列表等.
我假设我必须使用某种事件处理程序?
我不介意被指向第三方库的方向,例如NLog.
更新
我需要在内存中维护一个集合,它反映当前的控制台状态(然后我可以使用套接字发送到远程WinForms应用程序).除了细节之外,我想我可以用几行C#来做到这一点 - 我不想添加一个巨大的日志库而不需要它.
Console类允许您替换输出和错误流.正如您在此需要的那样,您可以使用TextWriter替换它们,TextWriter也会记录所写的内容.示例实现:
class ConsoleLogger : System.IO.TextWriter {
private System.IO.TextWriter oldOut;
private Queue<string> log = new Queue<string>();
private StringBuilder line = new StringBuilder();
private object locker = new object();
private int newline;
private int logmax;
public ConsoleLogger(int history) {
logmax = history;
oldOut = Console.Out;
Console.SetOut(this);
}
public override Encoding Encoding {
get { return oldOut.Encoding; }
}
public override void Write(char value) {
oldOut.Write(value);
lock (locker) {
if (value == '\r') newline++;
else if (value == '\n') {
log.Enqueue(line.ToString());
if (log.Count > logmax) log.Dequeue();
line.Length = newline = 0;
}
else {
for (; newline > 0; newline--) line.Append('\r');
line.Append(value);
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
用法:
static void Main(string[] args) {
var outLogger = new ConsoleLogger(100);
// etc...
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1717 次 |
| 最近记录: |