我注意到我写的一个对象的完全限定名称回来很有趣。在逐步执行我的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)
答案 0 :(得分:12)
现在您已经发布了更多程序,问题很明显。 Char plus int不是字符串。请记住,
string += char + int + char + int
表示:
string = string + (((char + int ) + char) + int)
当你向一个char添加一个int时,你得到一个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;
这使得一切都成为一个字符串。
答案 1 :(得分:1)
我复制粘贴你的代码,它工作正常
答案 2 :(得分:1)
问题发生了,因为右边的表达式不是字符串表达式。您正在处理未自动转换为字符串的字符和整数,除非它们在字符串表达式中使用。您可以通过以字符串开头(此处为空字符串)使其成为字符串表达式:
toReturn += "" + separator + userID + separator + contentID;