【发布时间】:2013-05-09 21:31:26
【问题描述】:
我有一个函数可以接受一个数字,它将其转换为 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 个写入命令,但我需要缩进下一行而不擦除缩进的空格内。
【问题讨论】:
-
嗯,当然它更慢,你在这里有更多的
Write电话。您可以做的是创建一个嵌入新行的字符串,然后尝试立即将其放在控制台上。我不知道说您可以使用数组更快地做到这一点是什么意思,但可能不是您所理解的 -
您可以先使用
StringBuilder创建整行(或整个输出),然后将其完整输出到屏幕。 -
或者你可以尝试类似示例 2 的链接:dotnetperls.com/convert-string-byte-array 它似乎在使用数组,但这一切都回退到输出一个字符串到控制台而不是多个
-
如果从一开始就知道字符串,@Davio
StringBuilder会更慢。如果他只是在代码中创建一个字符串,编译器会很好地优化它 -
当然,您始终可以添加包含所有 256 个不同可能字符串的查找表。 ^^