我有一个函数接受一个数字,它会将它转换为5x7的数字图形表示,如下所示:
Console.WriteLine(" ███ "); // byte: 0000 1110
Console.WriteLine("█ █"); // 0001 0001
Console.WriteLine("█ █"); // 0001 0001
Console.WriteLine("█ █"); // 0001 0001
Console.WriteLine("█ █"); // 0001 0001
Console.WriteLine("█ █"); // 0001 0001
Console.WriteLine(" ███ "); // 0000 1110
我被告知可以使用字节数组更快地完成。 这基本上就是我做的:
byte[] data = new byte[] { 14, 17, 17, 17, 17, 17, 14 };
BitArray bitData = new BitArray(data);
int bitCounter = 0;
foreach (bool bit in bitData)
{
if (bit)
Console.Write("█");
else
Console.Write(" ");
bitCounter++;
if (bitCounter>7)
{
bitCounter=0;
Console.WriteLine();
}
}
这比开始时慢,所以我不能使用它。 有人能告诉我更好的方法吗?
更新: StringBuilder确实有帮助,但它会比我原来的代码慢一点。它仍然基本上在控制台中使用7次写入命令正在减慢我的速度。 我尝试使用\ n只使用1个写命令,但我需要缩进下一行而不删除缩进空格内。
答案 0 :(得分:1)
我最小化了IO。以下版本仅在最后进行控制台调用。
var stringBuilder = new StringBuilder();
bitCounter = 0;
foreach (bool bit in bitData)
{
if (bit)
stringBuilder.Append("█");
else
stringBuilder.Append(" ");
bitCounter++;
if (bitCounter > 7)
{
bitCounter = 0;
Console.WriteLine(stringBuilder.ToString());
stringBuilder.Clear();
}
}