java里面有 String StringBuffer, String对象会有自己的pool,内容不可变,但是我们平时用的String变量都是String的引用。

字符串连接操作,StringBuffer.append 会比String的+=高效率很多,尤其频繁连接操作的时候。

String s=new String(“ddddd”);创建两个对象一个是常量”ddddd“,一个是它的引用s。 s可以重新指向别的对象。此时String s2=“ddddd”;就是只创建了一个象引用,而且此时s==s2 是true。而String s2=new String(“ddddd”);就是两个对象,而且s==s2是false,只有通过s.equal(s2)才可以真正判定二者内容的相等性。

c++里面的string多少会跟char*,有点联系,string.c_str() 返回的就是char*,但是以“\0”结尾,data()返回的不是“\0”结尾,但是二者长度是一样的。

说到char* 又会跟内存联系上,内存申请,内存释放,字符串的连接,包含,截取,比较等等操作,着实可以考验一个人使用c++语言的功底。

下面就列举几个c++字符串的实现吧:

很多人认为C语言中的难点是指针,对指针的理解直接关系到所编程序的好坏,所以,
在这里列举了一些C编译器通常都有的标准函数的源代码,看过它们,就能对指针和字符串
有所了解了.
1. strlen(),计算字符串长度

int strlen(const char string) 
{ 
int i=0; 
while(string[i]) i++; 
return i; 
}


2. strcpy(), 字符串拷贝.

char *strcpy(char *destination, const char *source) 
{ 
while(*destinaton++=*source++); 
return (destination-1); 
}


3. strcat(), 字符串的连接.

char *strcat(char *target,const char *source) 
{ 
char *original=target; 
while(*target) target++;     // Find the end of the string 
while(*target++=*source++); 
return(original); 
}


4. streql(), 判断两个字符串是否相等.

int streql(char *str1,char *str2) 
{ 
while((*str1==*str2)&&(*str1)) 
{ 
str1++; 
str2++; 
} 
return((*str1==NULL)&&(*str2==NULL)); 
}


5. strchr(), 在字符串中查找某个字符.

char *strchr(const char *string,int letter) 
{ 
while((*string!=letter)&(*string)) 
string++; 
return (string); 
}


6. chrcnt(), 计算某个字符在字符串中出现的次数.

int chrcnt(const char *string,int letter) 
{ 
int count=0; 
while(*string) 
if(*string==letter)count++; 
return count; 
}


7. strcmp(), 判断两个字符串是否相等.

int strcmp(const char *str1,const char *str2) 
{ 
while((*str1==*str2)&&(*str1)) 
{ 
str1++; 
str2++; 
} 
if((*str1==*str2)&&(!*str1)) //Same strings 
return o; 
else if((*str1)&&(!*str2))  //Same but str1 longer 
return -1; 
else if((*str2)&&(!*str1)) //Same but str2 longer 
else 
return((*str1>*str2)?-1:1); 
}

3.c++string 有个特点 就是内存共享,和copy On Write,这种特性,使得有时会造成的bug就是,某些内存还有人在用,却被释放掉了。因为,两个内容一样的string起初会共享一块内存,直到有一个字符串要执行写入操作的时候,才会分开两块内存。这是string之间互相赋值的时候,才会发生内存共享,避免这种情况,可以将一个字符串的char*赋值过去,就可以开辟新内存了。我曾经遇到过隐式内存泄露,就是内存没有及时释放导致,内存不够用了,这是大数据处理的非常需要注意的。 此外 我还遇到过一次性内存泄露。

下面 的讲解虽然不是很精确,但是算是比较全面的了,可以参考。