gpt4 book ai didi

c# - 了解在 C# 和 Java 中产生不同结果的字符串的显式转换

转载 作者:行者123 更新时间:2023-11-30 18:52:48 27 4
gpt4 key购买 nike

我为 Java 7 和 C#(.net 3.5) 编写了一段相同(..相似?)的代码,但得到了令人困惑的输出。请帮助我理解这种行为:

Java:

public class strTest {
public static void main(String [] s) {
String s1 = "abc";
String s2 = new String(new char[] {'a', 'b', 'c'});
System.out.println(s1 == s2); // false
System.out.println(((Object)s1) == ((Object)s2)); // false
System.out.println(s1.equals(s2)); // true
}
}

输出:错误错误的是的

C#:

namespace ConsoleApplication1
{
class Program2
{
static void Main(string[] args)
{
String s1 = "abc";
String s2 = new String(new Char[] {'a', 'b', 'c'});
Console.WriteLine(s1 == s2); // true
Console.WriteLine(((Object)s1) == ((Object)s2)); // false
Console.WriteLine(s1.Equals(s2)); // true
}
}
}

输出:真错误的是的

我知道 String 不变性和 String 池等概念,但我想我错过了更详细的说明。

在 java 中:当它可以使用 s1 引用的字符串对象时,为什么要为 s2 创建一个新的字符串对象?这不是字符串池应该实现的吗?

最佳答案

您的问题有两个方面:创建对象的时间以及== 比较的工作方式:

对象创建

就驻留(“池化”)而言 - 只有常量 会自动驻留。您可以使用 Intern/intern 来实习其他字符串,但是当您只调用将总是创建新字符串的字符串构造函数时。 (好吧,除了 .NET 中的一个奇怪的极端情况,但我们现在可以忽略它。)

所以在你的代码中,s1s2 总是引用不同的对象。

比较

造成差异的原因是您使用了 ==。 C#支持自定义运算符重载,String重载如下:

public static bool operator ==(string x, string y)

比较字符串的内容而不是引用。因此,当您有两个 string 类型的操作数时,x == y 最终会进行相等比较而不是恒等比较。这就是 C# 输出的第一行是 True 的原因。

Java 没有有这种行为,这就是打印 false 的原因。

当操作数类型为 Object 时,C# 和 Java 都将使用引用相等性,这就是为什么第二行在两种情况下都为 false 的原因。

关于c# - 了解在 C# 和 Java 中产生不同结果的字符串的显式转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11133309/

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