我注意到我写的对象的完全限定名称返回时很有趣。在逐步执行我的 ToString() 方法时,我注意到在连接字符串时,字符对象始终被排除在该过程之外。
这是发生的事情的一个步骤
之前
之后
哪里 Char seperator = ':';
这是我的 tostring 函数的代码:
public String ToString(Representaion rep)
{
String toReturn = "kuid";
Char separator = ':';
switch (rep)
{
case Representaion.Colons:
break;
case Representaion.Underscores:
separator = '_';
break;
case Representaion.UCROnly:
toReturn = userID + ":" + contentID;
toReturn += revision == 0 ? "" : ":" + revision;
return toReturn;
}
toReturn += version == 0 ? "" : version.ToString();
toReturn += separator + userID + separator + contentID;
toReturn += revision == 0 ? "" : separator + revision.ToString();
return toReturn;
}
你在哪里
private byte version;
private int userID;
private int contentID;
private byte revision;
一个案例可能是这样的:
在本地面板中,似乎 VS 得到的字符串与我认为的不同。
我放入另一个 ToString 函数来处理不带参数的调用(它通过调用带有 Representation.Colons 的参数化函数来实现):
public override string ToString()
{
return this.ToString(KUID.Representaion.Colons);
}
谁能告诉我为什么我没有得到我认为应该得到的东西? (预期结果:kuid2:72938:40175:2)
最佳答案
既然您已经发布了更多程序,问题就很明显了。 Char 加 int 不是字符串。 记住,
string += char + int + char + int
意思是:
string = string + (((char + int ) + char) + int)
当你将一个 int 添加到一个 char 时,你会得到一个 int:'a' + 2
生成对应于 'c'
的整数字符代码,而不是字符串 "a2"
.
通过将用户 ID 添加到冒号字符,您将获得一些疯狂的整数。
像这样连接字符串是一种不好的做法,这正是您遇到的原因。相反,说:
return string.Format("kuid{0}{1}{2}{3}{4}{5}{6}",
version, separator, userID, separator, contentID,
revision == 0 ? "" : separator.ToString(),
revision == 0 ? "" : revision.ToString());
或者,更好的是,使用 StringBuilder
对象来构建复杂的字符串。
顺便说一句,这说明了关于该语言的一个有趣的观点:
a += b + c;
不代表
a = (a + b) + c;
意思是
a = a + (b + c);
正如我们所见,可能会有不同的类型分析!你有没有说:
string = string + char + int + char + int
那么这将被分析为
string = ((((string + char) + int) + char ) + int;
这确实使一切成为字符串。
关于c# - 在字符串连接中忽略 Char 对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14008749/