深入解析C++和JAVA的字符串_C 语言

所有的字符串类都起源于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都是大同小异的。

以上就是本文的全部内容,希望对大家的学习有所帮助。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索java
, c++
字符串
java深入解析、java深入解析 pdf、java深入解析 pdf下载、深入解析java web、c语言解析json字符串,以便于您获取更多的相关知识。

时间: 2025-01-26 08:12:40

深入解析C++和JAVA的字符串_C 语言的相关文章

C++实现从输入中读取字符串_C 语言

你可以用这种方式读取一个单独的以空格结束的词: #include<iostream> #include<string> using namespace std; int main(){ cout << "Please enter a word:\n"; string s; cin>>s; cout << "You entered " << s << '\n'; } 注意,这里没有显式

详细解析命令行的getopt_long()函数_C 语言

头文件 #include<getopt.h> 函数原型int getopt_long(int argc,char * const argv[],const char *optstring,const struct option *longopts,int *longindex) 函数说明getopt被用来解析命令行选项参数.getopt_long支持长选项的命令行解析,函数中的参数argc和argv通常直接从main()的两个参数传递而来.optstring是选项参数组成的字符串. 字符串op

设计模式中的备忘录模式解析及相关C++实例应用_C 语言

备忘录模式旨在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可将该对象恢复到原先保存的状态.在命令模式中,备忘录模式经常还经常被用来维护可以撤销(Undo)操作的状态. 类图: Originator:负责创建一个备忘录Memento,用以记录当前时刻它的内部状态,并可使用备忘录恢复内部状态.Originator可根据需要决定Memento存储Originator的哪些内部状态. Memento:负责存储Originator对象的内部状态,并可防止Origin

深入解析C++编程中范围解析运算符的作用及使用_C 语言

范围解析运算符 :: 用于标识和消除在不同范围内使用的标识符. 语法 复制代码 代码如下: :: identifier class-name :: identifier namespace :: identifier enum class :: identifier enum struct :: identifier 备注identifier 可以是变量.函数或枚举值.具有命名空间和类以下示例显示范围解析运算符如何与命名空间和类一起使用: namespace NamespaceA{ int x;

C语言 文件操作解析详解及实例代码_C 语言

C语言文件操作解析         在文件操作中除了打开操作以及读写操作,还有几种比较常见的操作.下面介绍一下这些操作中涉及到的函数. 一.移动位置指针的函数    rewind函数和fseek函数,这两个函数的原型是:    void rewind(FILE *fp);     将位置指针移动到文件首   int fseek(FILE *fp,long int offset,int origin);   将位置指针移动到距离origin的offset字节数的位置   其中对于fseek函数中的

解析C++ 浮点数的格式化显示_C 语言

代码如下所示: 复制代码 代码如下:     #include <stdlib.h>      #include <string>      #include <windows.h>      #include <stdio.h>      #include <iostream>      #include <limits>      #include <sstream>      using namespace std;

深入解析C++中的mutable关键字_C 语言

mutalbe的中文意思是"可变的,易变的",跟constant(既C++中的const)是反义词. 在C++中,mutable也是为了突破const的限制而设置的.被mutable修饰的变量,将永远处于可变的状态,即使在一个const函数中. 我们知道,如果类的成员函数不会改变对象的状态,那么这个成员函数一般会声明成const的.但是,有些时候,我们需要在const的函数里面修改一些跟类状态无关的数据成员,那么这个数据成员就应该被mutalbe来修饰. 下面是一个小例子: 复制代码

华为面试题答案找出最大长度子字符串_C 语言

复制代码 代码如下: int findMaxSubstring(char* str){    int maxLength = 0;    int maxStartIndex = 0;    int curLength = 0;    int curStartIndex = 0;    bool isFind = 0;    for(unsigned int i = 0;i<strlen(str);i++)    {        if(str[i] >= 'a' && str[

深入解析C++ Data Member内存布局_C 语言

如果一个类只定义了类名,没定义任何方法和字段,如class A{};那么class A的每个实例占用1个字节的内存,编译器会会在这个其实例中安插一个char,以保证每个A实例在内存中有唯一的地址,如A a,b;&a!=&b.如果一个直接或是间接的继承(不是虚继承)了多个类,如果这个类及其父类像A一样没有方法没有字段,那么这个类的每个实例的大小都是1字节,如果有虚继承,那就不是1字节了,每虚继承一个类,这个类的实例就会多一个指向被虚继承父类的指针.还有一点值得说明的就是像A这样的类,编译器不