gpt4 book ai didi

c# - Foreach 循环 - 长字符串的性能

转载 作者:太空宇宙 更新时间:2023-11-03 21:46:49 27 4
gpt4 key购买 nike

我的 C# 应用程序遇到性能问题。问题是一个很长的字符串 - base64 编码,但不普通。偶数字符必须向上移动 5 个字符,奇数字符必须向下移动 5 个字符,以创建可读的 base64 字符串。这是我的代码:

string b64stock; // <- long one
int b = 0;
string b64readable = "";
foreach (char c in b64Stock)
{
if ((b % 2) == 0)
{
int asciichar = (int)c;
asciichar += 5;
b64readable += (char)asciichar;
}
else
{
int asciichar = (int)c;
asciichar -= 5;
b64readable += (char)asciichar;
}
b++;
}

我用秒表检查了代码。执行循环需要 17 秒。我应该采取什么步骤来提高效率?

最佳答案

使用 StringBuilder 而不是字符串:

string b64stock; // <- long one
int b = 0;
StringBuilder sb = new StringBuilder(b64Stock.Length);
foreach (char c in b64Stock)
{
int asciiChar = (int)c;
if ((b % 2) == 0)
{
asciichar += 5;
}
else
{
asciichar -= 5;
}
sb.Append((char)asciichar);
b++;
}
string b64readable = sb.ToString();

您遇到的性能问题是因为字符串是不可变的。当您编写 myString += 'x' 时,它不会修改 myString。相反,它创建一个所需长度的新字符串并将旧的 myString 复制到它。即使对于相对较短的字符串,这也会降低性能。

StringBuilder 按您预期的方式工作。调用 Append 向缓冲区添加一个字符,缓冲区会根据需要自动扩展。虽然在这种情况下它根本没有扩展,因为我预先分配了它所需的长度。

关于c# - Foreach 循环 - 长字符串的性能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16554528/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com