c++字符串比较大小规则_c++字符串比较函数

c++字符串比较大小规则_c++字符串比较函数,第1张

c++字符串比较大小规则_c++字符串比较函数 01—char[]和char*之间的比较和转换在C++编程中,很多时候我们会遇到如何对char[]和char*进行比较,当然一般来说都是通过使用strcmp方法,当然看了C++ primer的话都知道不能使用“==”,那么先看看直接使用“==”是什么样的结果。

如下面的程序:#includeusing namespace std;int main() { char arrTest1[] = "abc"; char arrTest2[] = "abc"; cout << (arrTest1== arrTest2) << endl; char *pTest1 = "abc"; char *pTest2 = "abc"; cout << (pTest1 == pTest2) << endl;}这个程序的结果是:第一个打出的是0,而第二个打出的是1问题分析:那么为什么会有这种结果呢,首先需要知道的是这里“==”比较的不是指向的内容abc,比较的是各个arrTest1和arrTest2对象中存储的是指向内容的地址,换句话说就是abc的地址,不是它们本身的存储的值。

Array对象对Array对象来说,是运行时在栈空间上分配的内存,所以每个对象都是单独去申请内存,各自保存一份自己的abc,所以Array对象存储的地址也是不一样的,所以第一个结果是false;Pointer对象对Pointer对象来说,两个字符指针并没有分配相应的存储区,是后面的abc是以字符串常量的形式存在常量区,然后把首地址的值赋值给了Pointer对象,所以Pointer对象存储的地址应该来说是一样的,所以第二个结果是true;我们可以想到通过打印相关的地址来查看结果是否正确,但这里会有个问题:数组对象下面直接打印数组对象,其实是打印的数组对象的内容,结果都是abccout << arrTest1<< endl;cout << arrTest2<< endl;对于数组对象可以这样打印数组的首地址,可以从这里看出这两个地址是不同的,即两个abc存储在不同的空间cout << &arrTest1<< endl;cout << &arrTest2<< endl;输出结果如下:指针对象下面直接打印指针对象,其实是打印的也是指针对象的内容,结果都是abc,这样打印按道理来说应该是打印的字符串的首地址,是因为对cout进行了重载,打印字符指针时,给出地址不是打印地址内容,而是打印相对的字符的内容,所以会得到abc结果cout << pTest1 << endl; cout << pTest2 << endl;但是如果取该指针的地址来打印的话,结果两个地址是不对的,因为此时打印的不是指向的字符串的首地址了,而是该指针变量的地址,当然不一样cout << &pTest1 << endl; cout << &pTest2 << endl;如果要获取指针对象的字符串的首地址的值的话,需要让cout输出符不认为它是一个字符指针,这样就不会产生重载 *** 作了,这样可以看到两个输出的地址是相同的cout << (void*)pTest1<< endl; cout << (void*)pTest2<< endl;输出结果如图:那么直接比较char[]时,可以使用如下函数方式:如果要比较的对象是char*字符串int strcmp(const char* s1,const char* s2); char a[10]=”abc”,c[1000]=”abc”; printf(“%d”,strcmp(a,c)); //返回 0 表示相等2. 如果要比较的对象是两个string,则利用函数compare() 或者 ==s1.compare(s2)3. 注意:C++中string类型与char*类型的字符串比较的一种实例,使用strcmp比较时需先将string转换成char*类型再比较,此时可以用c_str()函数转换。

当然compare其中有一个重载如下,可以直接使用于string与char*或者与char[]进行对比int compare (const char* s) const;#include <iostream>#include <cstring>using namespace std;int main(void){ const char *passwd = "ap_passwd"; string str = "ap_passwd"; cout<<"passwd="<<passwd<<", str="<<str<<endl; if ( str.compare(passwd) == 0) { cout<<"The compare euqal!"<<endl; } else { cout<<"is not equal!"<<endl; } return 0;}运行:passwd=ap_passwd, str=ap_passwdThe compare euqal!02—三者之间的转换三者之间的转换1. string类如何转换为char *呢?首先必须了解,string可以被看成是以字符为元素的一种容器。

字符构成序列(字符串)。

有时候在字符序列中进行遍历,标准的string类提供了STL容器接口。

具有一些成员函数比如begin()、end(),迭代器可以根据他们进行定位。

注意,与char*不同的是,string不一定以NULL(‘’)结束。

string长度可以根据length()得到,string可以根据下标访问。

所以,不能将string直接赋值给char*。

把string转换为char* 有3种方法:1.datastring str="abc";char *p=(char *)str.data();2.c_strstring str="gdfd";char *p=str.c_str();3. copystring str="hello";char p[40];str.copy(p,5,0); //这里5,代表复制几个字符,0代表复制的位置*(p+5)=''; //要手动加上结束符2.char[]转换为string类直接赋值即可。

3. string类转换为char[]char *strcpy(char *a,const char *b){ if(a == NULL || b == NULL) exit(0); char *c = a; while((*a++ = *b++) != ''); return c;}char c[20];string s="1234";strcpy(c,s.c_str())

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/663753.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-18
下一篇 2022-04-18

发表评论

登录后才能评论

评论列表(0条)

保存