【Java学习笔记六】常用数据对象之String

字符串

在Java中系统定义了两种类型的字符串类:StringStringBuffer
String类对象的值和长度都不能改变,称为常量字符串类,其中每个值称为常量字符串。
StringBuffer类对象的值和长度都可以改变,称为变量字符串类,其中每个值称为可变字符串。
一个用双引号括起来的字符串属于String类的一个对象,通过new运算和String类的构造函数能够创建一个String类的实例对象。String 类的构造函数是一个重载函数,它可以不带任何参数。此时将创建一个空的字符串,该字符串中不包含任何字符。

它可以带有一个String类对象的参数,此时将创建与此对象值相同的字符串。还可以带有一个字符数组参数,此时将创建与此字符数组值相同的字符串实例对象。
例如:

String s=new String(); 
String r=new String("Apple"); 
String w="Apple"; 
String t=new String(r);
char []a={'a','b','c','d','e','f'}; 
String ss=new String(a);
String sss=new String(a,2,3); //sss="cde"

如果直接使用给字符串赋值常量字符串而不调用构造函数的方式,如:String s1="China";
则会将“China”放入内存池中,如果在后面再定义String s2="China"则s1和s2指向同一个位置,他们的指针值都是相同的,但是如果使用构造函数例如String s3=new String("China");的话则s3的值和s1、s2不同。

直接赋值的方法相当于再字符串池李寻找是否有相同内容的字符串,如果没有就将新对象放入内存池中,否则就使用内存池中已经存在的字符串。而用new的话会分配新的内存。

如果想要判断两个字符串的值是否相同可以使用字符串成员函数equal来进行判断,如果直接使用判等符号==的话判断的是指针值是否相同,这个值一般都是不同的。例如:s1.equal(s3)会返回真值。

成员函数:

  • int length()返回当前字符串的长度,即字符个数
  • char charAt(int i)返回字符串中序号为i的字符,序号从0开始。
  • int indexOf(String s)从当前字符串对象中查找子字符串s,若找到则返回第一个字符的位置序号,否则返回-1。
  • int indexOf(String str, int fromIndex)从指定的索引处开始,返回第一次出现的指定子字符串在该字符串中的索引。
  • String substring(int i, int j)返回当前字符串对象中从序号i开始的、到序号j-1结束的一个子字符串对象,长度为j-i。
  • String concat(String s)返回当前字符串与参数串s进行首尾连接后的串。与加号(+)连接相同。如 s1.concat(s2)等于s1+s2
  • String replace(char x, char y)返回把当前串中的x字符 替换为y字符后得到的字符串对象。如:“abcda”.replace(‘a’, ‘f’),返回值为"fbcdf"
  • int compareTo(String s)返回当前串与参数串s的比较结果,当s较小则返回正数,当s较大则返回负数,相等返0。
  • boolean equals(Object s)判断当前串与参数串s是否相等,若相等则返回逻辑值真true,否则返回假false。
  • String toString()返回当前字符串对象。如s.toString()返s
  • String trim()返回从当前字符串中去掉首部和尾部空白字符后的字符串,空格、回车、换行、制表符等都是空白字符。
  • String toLowerCase()返回把当前串中的全部大写字母变为小写字母后得到的字符串。如"ABbcd".toLowerCase()返"abbcd"
  • String toUpperCase() 返回把当前串中的全部小写字母变为大写字母后得到的字符串。如"ABbcd".toUpperCase()返"ABBCD"

String内封装的是不可变的字符串,如果要将其进行一些处理,就必须得到返回值。

StringBuffer类就可以避免这个问题,StringBuffer类对可变字符串进行处理,可以调用函数进行字符串操作。

  • StringBufferappend(各种类型)在字符串末尾添加各种类型
  • StringBuffer insert(int offset, 各种类型)在某个位置添加各种类型
  • deleteCharAt(int index) / StringBuffer delete(int start, int end)删除字符或者某一段字符串

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/383807.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Java学习笔记七】常用数据对象之数组

同一般的对象创建和定义一样&#xff0c;数组的定义和创建可以分开进行也可以合并一起进行。 一维数组定义格式&#xff1a; <元素类型>[] <数组名>;//[]也可以放在数组名的后面一维数组创建格式&#xff1a; new <元素类型>[<元素个数>];执行new运…

yfan.qiu linux硬链接与软链接

http://www.cnblogs.com/yfanqiu/archive/2012/06/11/2545556.html Linux 系统中有软链接和硬链接两种特殊的“文件”。 软链接可以看作是Windows中的快捷方式&#xff0c;可以让你快速链接到目标档案或目录。 硬链接则透过文件系统的inode来产生新档名&#xff0c;而不是产生…

【Java学习笔记八】包装类和vector

包装类 在Java语言中&#xff0c;每一种基本的数据类型都有相应的对象类型&#xff0c;称为他们基本类型的包装类&#xff08;包裹类&#xff09;。 字节byte&#xff1a;Byte、短整数型short&#xff1a;Short 标准整数型int&#xff1a;Integer、长整数型long&#xff1a;Lo…

Linux C++线程池实例

http://www.cnblogs.com/danxi/p/6636095.html 想做一个多线程服务器测试程序&#xff0c;因此参考了github的一些实例&#xff0c;然后自己动手写了类似的代码来加深理解。 目前了解的线程池实现有2种思路&#xff1a; 第一种&#xff1a; 主进程创建一定数量的线程&#xff0…

Java编写简单的自定义异常类

除了系统中自己带的异常&#xff0c;我们也可以自己写一些简单的异常类来帮助我们处理问题。 所有的异常命名都是以Exception结尾&#xff0c;并且都是Exception的子类。 假设我们要编写一个人类的类&#xff0c;为了判断年龄的输入是否合法&#xff0c;我们编写了一个名为Il…

shared_ptr简介以及常见问题

http://blog.csdn.net/stelalala/article/details/19993425 本文中的shared_ptr以vs2010中的std::tr1::shared_ptr作为研究对象。可能和boost中的有些许差异&#xff0c;特此说明。 基本功能 shared_ptr提供了一个管理内存的简单有效的方法。shared_ptr能在以下方面给开发提供便…

【Java学习笔记九】多线程

程序&#xff1a;计算机指令的集合&#xff0c;它以文件的形式存储在磁盘上&#xff0c;是应用程序执行的蓝本。 进程&#xff1a;是一个程序在其自身的地址空间中的一次执行活动。进程是资源申请、调度和独立运行的单位&#xff0c;因此&#xff0c;它使用系统中的运行资源。而…

【C++11新特性】 C++11智能指针之weak_ptr

http://blog.csdn.net/xiejingfa/article/details/50772571 原创作品&#xff0c;转载请标明&#xff1a;http://blog.csdn.net/Xiejingfa/article/details/50772571 如题&#xff0c;我们今天要讲的是C11引入的三种智能指针中的最后一个&#xff1a;weak_ptr。在学习weak_ptr之…

【C++学习笔记四】运算符重载

当调用一个重载函数和重载运算符时&#xff0c;编译器通过把您所使用的参数类型和定义中的参数类型相比较&#xff0c;巨鼎选用最合适的定义。&#xff08;重载决策&#xff09; 重载运算符时带有特殊名称的函数&#xff0c;函数名是由关键字operator和其后要重载的运算符符号…

【C++11新特性】 C++11智能指针之unique_ptr

原创作品&#xff0c;转载请标明&#xff1a;http://blog.csdn.net/Xiejingfa/article/details/50759210 在前面一篇文章中&#xff0c;我们了解了C11中引入的智能指针之一shared_ptr&#xff0c;今天&#xff0c;我们来介绍一下另一种智能指针unique_ptr。 unique_ptr介绍 uni…

C++派生类对象和基类对象赋值

在C中&#xff0c;我们允许 将派生类对象赋给基类对象。&#xff08;不允许将基类对象赋给派生类对象&#xff09; 只会将基类对象成员赋值用基类指针指向派生类对象。&#xff08;不允许用派生类指针指向基类对象&#xff09; 基类指针只能操作基类中的成员基类引用作为派生类…

【C++11新特性】 C++11智能指针之shared_ptr

http://blog.csdn.net/Xiejingfa/article/details/50750037 原创作品&#xff0c;转载请标明&#xff1a;http://blog.csdn.net/Xiejingfa/article/details/50750037 C中的智能指针首先出现在“准”标准库boost中。随着使用的人越来越多&#xff0c;为了让开发人员更方便、更安…

C++(纯)虚函数重写时访问权限更改问题

我们知道在Java中是自动实现多态的&#xff0c;Java中规定重写的方法的访问权限不能缩小。那么在C中我们实现多态的时候是否可以更改&#xff08;缩小&#xff09;访问权限呢&#xff1f; 经过测试&#xff0c;得到的答案如下&#xff1a;如果用基类指针指向派生类对象实现多态…

C++ — 智能指针的简单实现以及循环引用问题

http://blog.csdn.net/dawn_sf/article/details/70168930 智能指针 ____________________________________________________ 今天我们来看一个高大上的东西&#xff0c;它叫智能指针。 哇这个名字听起来都智能的不得了&#xff0c;其实等你了解它你一定会有一点失望的。。。。因…

C++(静态)(常量)数据进行初始化问题以及静态变量析构

在C11标准以前我们都不可以在类中对数据成员初始化&#xff0c;仅能在构造函数中进行初始化&#xff1a; class A {int a,b; double c; string d;A():a(1),b(2),c(3),d(""){} };在C11标准以后我们可以在类中对非静态成员进行初始化。实际上的机制是在调用构造函数的…

C++this指针的用法

参考博客&#xff1a;https://www.cnblogs.com/zhengfa-af/p/8082959.html 在 访问对象的非静态成员时会隐式传递一个参数&#xff0c;即对象本身的指针&#xff0c;这个指针名为this。 例如&#xff1a; class A {int a1;public:A(){}void GetA(int a){cout<<this-&g…

C++开发者都应该使用的10个C++11特性

http://blog.jobbole.com/44015/ 感谢冯上&#xff08;治不好你我就不是兽医 &#xff09;的热心翻译。如果其他朋友也有不错的原创或译文&#xff0c;可以尝试推荐给伯乐在线。】 在C11新标准中&#xff0c;语言本身和标准库都增加了很多新内容&#xff0c;本文只涉及了一些皮…

C++不能被声明为虚函数

虚函数是为了实现多态&#xff0c;但是显然并不是所有函数都可以声明为虚函数的。 不能被声明为虚函数的函数有两类&#xff1a; 不能被继承的函数不能被重写的函数 因此&#xff0c;这些函数都不能被声明为虚函数 普通函数构造函数 如果构造函数定义为虚函数&#xff0c;则…

类的声明与定义

类的前向声明&#xff1a; class A;在声明之后&#xff0c;定义之前&#xff0c;类A是一个不完全类型&#xff0c;即知道A是一个类&#xff0c;但是不知道包含哪些成员。不完全类型只能以有限方式使用&#xff0c;不能定义该类型的对象&#xff0c;不完全类型只能用于定义指向…

shared_ptr的一些尴尬

http://blog.csdn.net/henan_lujun/article/details/8984543 shared_ptr在boost库中已经有多年了&#xff0c;C11又为其正名&#xff0c;把他引入了STL库&#xff0c;放到了std的下面&#xff0c;可见其颇有用武之地&#xff1b;但是shared_ptr是万能的吗&#xff1f;有没有什…