此代码看起来很复杂,因为作者试图尽可能多地将一个功能打包到一行中。 (如果我的心情较为平淡,我会称之为“炫耀”,如果大三学生试图检查这个问题,可能会抱怨。)但是,这行代码中没有任何一部分是复杂的;把它分开一点一点地分开,然后检查每一点。
对于初学者来说,第一行只是垃圾; ToInt32("a")
将抛出FormatException
,因为您没有指定16的基数,如:ToInt32("a", 16)
。如果你修复它,但它将返回10.ToString("x")
这是"a"
。所以忽略这一行,它没有任何用处。 (我们可以想象笔者打算使用类似Encoding.UTF8.GetBytes()
返回0x61
,但他们没有)
第二行,你打破每一位,并看看会发生什么:
String.Join(String.Empty,
这是很简单:它要采取字符串和join them together数组,使用String.Empty
作为分隔符
stringInput.Select(
这就是我们的使用LINQ建立的IEnumerable
(督察,没有分离。)串;它将逐个遍历字符串中的字符,并在每个字符串上执行lambda表达式。
c => Convert.ToString(
Convert.ToUInt32(c.ToString(), 16), 2).PadLeft(4, '0')));
在此处,它就会变得混乱,因为即使我匹配了由眼睛的括号是一种痛苦,但如果展开嵌套函数调用转换为临时工,您可以:
s = c.ToString(); // Convert the character to a string
u = Convert.ToUInt32(s, 16); // Convert a string of hex digits to a uint
b = Convert.ToString(u, 2); // Convert a uint to a string of binary digits.
return b.PadLeft(4, '0'))); // Add 0s to make the string at least 4 digits.
每一个那些“返回”值将成为枚举中的下一个元素,由Select
返回,然后加入。
这里的最终结果是你从一个从0到F的十六进制数字串开始,当它被读作一个数字时,它有一些特定的数字值,并且你最终得到一串二进制数字0和1 ,当作为数字读取时,具有相同的数值。 IOW,您正在将一串十六进制数字“转换”为二进制数字的“等价”字符串。
那么究竟是什么**你无法理解这一行? –
也许你应该在调试器中一次写一步。例如,'int i = Convert.ToInt32(“a”);'。然后看看'我'的价值是什么。然后'string s = i.ToString(“x”);'并检查's'的值。这会让你了解这些事情的作用。或者,您可以查看这些方法的文档。 –
@JimMischel我明白,i.toString(“x”);格式化文本,但它如何将“a”转换为十六进制而不指定其基数为16? –