深入解析C++和JAVA的字符串
所有的字符串类都起源于C语言的字符串,而C语言字符串则是字符的数组。C语言中是没有字符串的,只有字符数组。
谈一下C++的字符串:C++提供两种字符串的表示:C风格的字符串和标准C++引入的string类型。一般建议用string类型,但是实际情况中还是要使用老式C风格的字符串。
1.C风格的字符串:C风格字符串起源于C,并在C++中得到扩展。字符串存储在一个字符数组中,例如:
const char *str = “zhangdan”;(不要忘掉最后的\0)
这里用常量字符数组来表示字符串。操作字符串的时候只要操作指针就可以了。如 :
const char * str = "zhangdan"; const char *p = str; 然后对p进行操作就可以了。
2.标准C++的string类型:如果用的话首先要引入头文件:#include<string>
在C++中提供的标准字符串类型提供了以下操作:
(1).支持用字符序列或者第二个字符串去初始化一个字符串对象。C风格的字符串不支持用另外一个字符串初始化另外一个字符串。
(2).支持字符串之间的copy,C风格字符串通过strcpy()函数来实现。
(3).支持读写访问单个字符。对于C风格的字符串,只有解除引用或者通过下标操作才能访问单个字符。
(4).支持两个字符串相等比较,对于C风格的字符串,比较是通过strcmp()函数来实现的。
(5).支持两个字符串连接,对于C风格的字符串用strcpy() 函数copy到一个新的实例中,然后用strcat()把两个字符串接起来。如:
string str1 = "111111", str2 = "222222";
string str3 = str1 + str2;
(6).支持对字符串长度的查询:string s ("XXXXXXX"); str.size() 为字符串的长度。
相互转换:const char * str = str2.c_str(); //不可把字符串类型直接赋给字符数组,但是可以吧一个字符数组赋给一个字符串类型:如:const char *str = "zhangdan"; string str2 = str;
C++ string类的输入
(1)方法一:和C字符串输入的方法一相同。
(2)方法二:使用getline函数。
例如:string a;
getline(cin,a);
字符串到数字的转换
atoi函数获取一个C字符串参数,返回对应的int值。如果参数不与一个int值对应,atoi就会返回0。atoi函数在文件为cstdlib的库中。如果数字太大,不能转换成int类型的值,可以使用atol将字符串转换为long类型的值。
例如:
atoi("1234"); //返回整数1234
atoi("#123"); //返回0
C++中字符串的常用方法就不一一介绍,介绍几个常用的:begin(),end(),append(),等等。
2:JAVA中的字符串:在JAVA中,String不属于8中基本类型,所以String是对象,默认值是null
例如:String str = new String(); 和String str = new String("");是一个意思,就是构造一个空字符串,(理解null和""的区别)。
看下面这段代码:
String str = "xxx"; String str2 = new String("xxx"); System.out.println(str == str2); System.out.println(str.equals(str2));
结果是:
false
true
为什么呢? 在JAVA中 == 是对地址的比较,而equals是对内容的比较,为什么地址不一样呢?
先引入常量池的概念:
常量池(constant pool)指的是在编译期被确定,并被保存在已编译的.class文件中的一些数据。它包括了关于类、方法、接口等中的常量,也包括字符串常量。
当我们将一个字符串赋给一个字符串变量的时候,如String str = "xxxx"; 这时候,先去常量池中找有没有"xxxx"的字符串拷贝,如果有的话,把str的地址指向常量池中字符串常量"xxxx"的地址,如果没有则在常量池中建立"xxxx"的字符串常量。而 new String("xxxx")是放在堆内存中,有自己的内存空间。所以地址比较的时候不一样。
看下面一段代码:
String str = "zhang"; String str2 = "peng"; String str3 = "zhangpeng"; String str4 = "zhangpeng" str += str2; System.out.println(str == str3); System.out.println(str3 == str4)
结果为:
true
true
为什么呢?
首先,我们要知道Java会确保一个字符串常量只有一个拷贝。
因为例子中的str3和str4中的"zhangpeng"都是字符串常量,它们在编译期就被确定了,所以str3==str4为true;而"zhang"和"peng"也都是字符串常量,当一个字符串由多个字符串常量连接而成时,它自己肯定也是字符串常量,所以str2也同样在编译期就被解析为一个字符串常量,所以str2也是常量池中"zhangpeng"的一个引用。
JAVA 中String 和StringBuffer的区别:
String:
是对象不是原始类型.
为不可变对象,一旦被创建,就不能修改它的值.
对于已经存在的String对象的修改都是重新创建一个新的对象,然后把新的值保存进去.
String 是final类,即不能被继承.
StringBuffer:
是一个可变对象,当对他进行修改的时候不会像String那样重新建立对象
它只能通过构造函数来建立,
StringBuffer sb = new StringBuffer();
不能通过付值符号对他进行付值.
sb = "xxxxx";
对象被建立以后,在内存中就会分配内存空间,并初始保存一个null.向StringBuffer
中付值的时候可以通过它的append方法.
sb.append("hello");
字符串连接操作中StringBuffer的效率要比String高:
String str = new String("xxx");
str += "xx";
的处理步骤实际上是通过建立一个StringBuffer,然后调用append(),最后
再将StringBuffer toSting();
这样的话String的连接操作就比StringBuffer多出了一些附加操作,所以就慢了
问一个问题:为什么StringBuffer效率这么高,那么我们还要String呢?
不会的查一下吧,方向是常量池。
Python 字符串:
Python是一种强大的脚本语言,它定义字符串的时候不用定义类型。python字符串通常有单引号('...')、双引号("...")、三引号("""...""")或('''...''')包围,三引号包含的字符串可由多行组成,一般可表示大段的叙述性字符串。在使用时基本没有差别,但双引号和三引号("""...""")中可以包含单引号,三引号 ('''...''')可以包含双引号,而不需要转义。当需要特殊转义的时候可以用 '\'
python 也有很多字符串操作的函数。具体可以dir一把,跟C++和java都是大同小异的。
以上就是本文的全部内容,希望对大家的学习有所帮助。
最新评论