`
逆风的香1314
  • 浏览: 1438910 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

字符串相等(==)的全测试

阅读更多
  1. package p1;
  2. /**
  3.  * 字符串相等(==)的全测试。
  4.  * 
  5.  * @author XT Zang,老紫竹
  6.  */
  7. class TestString1 {
  8.   public static void main(String[] args) {
  9.     String hello = "Hello", lo = "lo";
  10.     System.out.print((hello == "Hello") + " "); // true
  11.     System.out.print((Other.hello == hello) + " "); // true
  12.     System.out.print((p2.Other.hello == hello) + " "); // true
  13.     System.out.print((hello == ("Hel" + "lo")) + " "); // true
  14.     System.out.print((hello == ("Hel" + lo)) + " "); // false
  15.     System.out.println(hello == ("Hel" + lo).intern()); // true
  16.   }
  17. }
  18. class Other {
  19.   static String hello = "Hello";
  20. }
  1. package p2;
  2. public class Other {
  3.   public static String hello = "Hello";
  4. }
结论:

This example illustrates six points:

  • Literal strings within the same class (§8) in the same package (§7) represent references to the same String object (§4.3.1).相同包,相同类的字符串常量指向相同的字符串对象

  • Literal strings within different classes in the same package represent references to the same String object.相同包,不相同类的字符串常量指向相同的字符串对象

  • Literal strings within different classes in different packages likewise represent references to the same String object.不同包,不同类的字符串常量指向相同的字符串对象

  • Strings computed by constant expressions (§15.28) are computed at compile time and then treated as if they were literals.字符串在编译期间可以连接起来的,视同一个常量字符串

  • Strings computed by concatenation at run time are newly created and therefore distinct.

The result of explicitly interning a computed string is the same string as any pre-existing literal string with the same contents.


参考地址:http://blog.csdn.net/ZangXT/archive/2008/10/11/3057471.aspx

分享到:
评论

相关推荐

    编写函数void fun(char *s,char *t,char *p)将未在字符串s中出现、而在字符串t中出现的字符, 形成一个新的字符串放在p中,p中字符按原字符串中字符顺序排列,但去掉重复字符。

    根据给定的信息,我们需要实现一个C语言函数`void fun(char *s,char *t,char *p)`,该函数的功能是:将未在字符串`s`中出现、而在字符串`t`中出现的字符形成一个新的字符串并存储在指针`p`指向的空间内。新字符串中...

    LabView(7.1)清除字符串中相同的字符

    在LabView(7.1)中,开发一个程序来清除字符串中的重复字符是一项常见的文本处理任务,这在数据清洗、信息处理或者特定算法实现时可能会用到。本实验的目的是教你如何利用LabView的编程能力,创建一个VI(虚拟仪器...

    判断字符串是否中心对称

    如果这两部分通过反转后相等,则字符串是中心对称的。例如,对于字符串 "madam",前半部分 "mad" 反转为 "dama",与后半部分 "mad" 相等,因此是中心对称的。 2. **双指针法**:设置两个指针,一个从字符串起始位置...

    在大字符串中寻找小字符串

    在大字符串中寻找小字符串是计算机编程中一个常见的任务,特别是在文本处理、数据搜索和算法设计等领域。这个任务通常被称为“子串查找”或“字符串匹配”。以下是对这个主题的详细探讨: 首先,我们需要理解基本...

    统计字符串中“子字符串”的个数

    1. **滑动窗口法**:通过设定一个固定长度的窗口(等于子字符串长度)在主字符串上滑动,每次比较窗口内的内容与子字符串是否相等。这种方法适用于无重叠且不需要正则匹配的情况。 2. **KMP算法**(Knuth-Morris-...

    字符串比较.docx

    - 该程序已经过测试,能够准确地完成字符串的比较任务,并根据结果输出正确的信息。 #### 四、总结 通过对以上内容的详细介绍,我们可以了解到在8086汇编语言环境下实现字符串比较的具体方法。这个程序不仅展示了...

    比较两个字符串是否相等的shell代码

    首先,最基础的字符串相等比较可以通过以下方式实现: ```bash if [ "$test"x = "test"x ]; then echo "两个字符串相等" else echo "两个字符串不相等" fi ``` 这里的重点在于: 1. 使用单个等号`=`进行比较。 2....

    Java 实例 - 测试两个字符串区域是否相等源代码-详细教程.zip

    这个教程将详细讲解如何在Java中测试两个字符串的特定区域是否相等,并提供相关的源代码实例。 首先,让我们了解Java中字符串的基本比较方法。`equals()`和`compareTo()`是最常见的两种方式。`equals()`方法用于...

    判断字符串是否回文 程序

    4. 比较并输出结果:将翻转后的字符串与原字符串比较,如果它们相等,则输出“是回文”,否则输出“不是回文”。 在压缩包中,`123.c` 文件很可能是该程序的源代码,使用C语言编写。C语言是一种底层、高效的编程...

    程判断输入的一串字符是否为“回文”。所谓“回文”是指顺序读和逆序读都一样的字符串。如:“12321”和“abcdcba”都是回文。

    `std::string`的`compare()`函数可用于字符串之间的比较,如果返回值为0,说明两个字符串相等。 3. **反转字符串**:一种直观的方法是先反转字符串,然后与原字符串比较。C++标准库没有提供直接反转字符串的函数,...

    C语言判断回文字符串代码.rar

    而"回文字符串判断.exe"是编译后的可执行文件,用户可以直接运行它来测试输入的字符串是否为回文。 在实际应用中,判断回文字符串的方法可以扩展到处理更复杂的情况,如忽略大小写、删除非字母数字字符等。这些功能...

    mysql 计算字符串相似度

    ### MySQL 计算字符串相似度 #### 背景与需求 在许多应用场景中,我们需要对两个字符串进行相似度比较,比如搜索引擎中的关键词匹配、文本分析中的近义词识别等。MySQL 提供了多种方法来实现字符串相似度的计算,...

    C++ 字符串匹配

    * Rabin-Karp 算法是基于哈希函数的字符串匹配算法,它使用一个哈希函数来计算主串和模式串的哈希值,然后比较两个哈希值是否相等。 * Boyer-Moore 算法是基于 Bad Character 规则和 Good Suffix 规则的字符串匹配...

    shell字符串的截取

    1. 使用 if 语句可以比较两个字符串是否相等,例如:if [ "$USER_NAME" = "terry" ]; then echo "I am terry" fi。 2. 使用 strCompare 函数可以比较两个字符串,例如:strCompare "$str1" "$str2"。 六、测试判空 ...

    C#编写的字符串、异常处理程序

    - `equals`:比较两个字符串是否相等。 - `insert`:在字符串的某个位置插入另一个字符串。 - `split`:根据分隔符将字符串分割成字符串数组。 - `tolower`:将字符串转换为小写。 - `trim`:去除字符串两端的...

    实验3 字符串应用与面向对象程序设计

    这可以通过遍历字符串,检查每个字符与其对应位置的倒数字符是否相等来实现。如果所有对应位置的字符都相等,则该字符串是2-重复串。 面向对象编程(OOP)是Java的核心特性。在这个项目中,我们将创建类来代表不同...

    map中字符串与结构体作key效率比较

    C++标准库为`std::string`提供了一个高效的比较函数,它通常是通过逐个字符比较直到找到不相等的字符或者到达字符串末尾来完成的。然而,由于字符串的动态性,每次插入或查找都需要进行内存管理和字符串拷贝,这可能...

    汇编语言-字符串匹配

    3. 比较:使用CMP指令比较两个字符,如果相等,则继续比较下一个字符,否则,根据是否到达文本字符串末尾,决定是否重新从文本的下一个位置开始匹配。 4. 终止:当模式字符串的全部字符都与文本字符串中的相应位置...

Global site tag (gtag.js) - Google Analytics