C++中string对象之间比较、char*之间比较

2023-09-17 19:49:57
#include <cstring> //char* 使用strcmp
#include <string> //string 使用compare
#include <iostream>
using namespace std;
int main() {
    string stringStr1 = "42";
    string stringStr2 = "42";
    string stringStr3 = "213";
    cout << "stringStr1: " << stringStr1 << " " << "&stringStr1 :" << &stringStr1 << endl; // stringStr1: 42 &stringStr1 :0x648d3ff910
    cout << "stringStr2: " << stringStr2 << " " << "&stringStr2 :" << &stringStr2 << endl; // stringStr2: 42 &stringStr2 :0x648d3ff8f0
    cout << "stringStr3: " << stringStr3 << " " << "&stringStr3 :" << &stringStr3 << endl; // stringStr3: 213 &stringStr3 :0x648d3ff8d0

    //  string类对象,可以用"=="进行比较,值相等时表达式的值为1,不相等则为0
    bool stringStr1_stringStr2 = stringStr1 == stringStr2;
    cout << "stringStr1 == stringStr2: " << stringStr1_stringStr2 << endl; // stringStr1 == stringStr2: 1
    // 若两个string对象长度不同,而且较短的string对象的每个字符都与较长string对象对应位置上的字符相同,就说较短string对象小于较长string对象:
    // 若两个string对象在某些对应的位置上不一致,则string 对象比较的结果其实是string对象中第一对相异字符比较的结果:
    bool stringStr1_stringStr3 = stringStr1 > stringStr3;
    cout << "stringStr1 > stringStr3: " << stringStr1_stringStr3 << endl; // stringStr1 > stringStr3: 1
    // str1.compare(str2),如果返回值为0则表示两个字符串相等。 1表示>,2表示<;
    bool stringStr1_stringStr3_compare = stringStr1.compare(stringStr3);
    cout<<"stringStr1.compare(stringStr3): "<<stringStr1.compare(stringStr3)<<endl; // stringStr1.compare(stringStr3): 1

    cout<<"------------------------------------------------------------------"<<endl;

    char* charStr1 = "42";
    char* charStr2 = "42";
    char* charStr3 = "213";
    // (void*)charStr1表示"42"本身的地址
    cout << "charStr1: " << charStr1 << " " << "(void*)charStr1 :" << (void*)charStr1 << endl; // charStr1: 42 (void*)charStr1 :0x7ff623c55001
    cout << "charStr2: " << charStr2 << " " << "(void*)charStr2 :" << (void*)charStr2 << endl; // charStr2: 42 (void*)charStr2 :0x7ff623c55001
    cout << "charStr3: " << charStr3 << " " << "(void*)charStr3 :" << (void*)charStr3 << endl; // charStr3: 213 (void*)charStr3 :0x7ff623c55004
    // &charStr1表示指向"42"的指针的地址
    cout << "charStr1: " << charStr1 << " " << "&charStr1 :" << &charStr1 << endl; // charStr1: 42 &charStr1 :0x648d3ff8c8
    cout << "charStr2: " << charStr2 << " " << "&charStr2 :" << &charStr2 << endl; // charStr2: 42 &charStr2 :0x648d3ff8c0
    cout << "charStr3: " << charStr3 << " " << "&charStr3 :" << &charStr3 << endl; // charStr3: 213 &charStr3 :0x648d3ff8b8
    // charStr1和charStr2存的就是”42“第一个字符的地址
    cout << "charStr1: " << charStr1 << " " << "*charStr1 :" << *charStr1 << endl; // charStr1: 42 *charStr1 :4
    cout << "charStr2: " << charStr2 << " " << "*charStr2 :" << *charStr2 << endl; // charStr2: 42 *charStr2 :4
    cout << "charStr3: " << charStr3 << " " << "*charStr3 :" << *charStr3 << endl; // charStr3: 213 *charStr3 :2

    // "=="不能用于两个char类型字符串的比较,对于char类型字符串来说,"=="比较的是两个字符串的起始地址。相当于比较的(void*)charStr1 :0x7ff6a9d25001,是字符串本身的地址
    bool charStr1_charStr2 = charStr1 == charStr2;
    cout << "charStr1 == charStr2: " << charStr1_charStr2 << endl; // charStr1 == charStr2: 1,因为charStr1和charStr2都指向”42“,内容都是”42“的存储地址,所以相等,相当于地址之间的比较
    bool charStr2_charStr3 = *charStr2 == *charStr3;
    cout << "*charStr2 == *charStr3: " << charStr2_charStr3 << endl; // *charStr2 == *charStr3: 0
    // 比的是原字符串的地址,没有意思
    bool charStr1_charStr3 = charStr1 > charStr3;
    cout << "charStr1 > charStr3: " << charStr1_charStr3 << endl; // charStr1 > charStr3: 0
    // 跟string的比较方式类似,逐个字符进行比较
    bool charStr1_charStr3_strcmp = strcmp(charStr1,charStr3);
    cout << "strcmp(charStr1,charStr3): " << charStr1_charStr3_strcmp << endl; // strcmp(charStr1,charStr3): 1


    int a = "42" > "213";
    int b = strcmp("42" , "213"); //逐个字符比较
    cout<<"'42' > '213': "<<a<<endl;
    cout<<"strcmp(\"42\" , \"213\"): "<<b<<endl;
    return 0;
}
  • string对象之间直接用>或<进行比较是按照字符顺序逐个比较;
  • char*类型的字符串之间直接用>或<比较的话,比的只是地址,用strcmp()方法的话也是诸逐个字符进行比较。
更多推荐

Zookeeper集群 + Kafka集群

Zookeeper概述//Zookeeper定义*Zookeeper是一个开源的分布式的,为分布式框架提供协调服务的Apache项目。//Zookeeper工作机制*****Zookeeper从设计模式角度来理解:是一个基于观察者模式设计的分布式服务管理框架,它负责存储和管理大家都关心的数据,然后接受观察者的注册,一旦

javascript基础第二天笔记

JavaScript基础-第2天理解什么是流程控制,知道条件控制的种类并掌握其对应的语法规则,具备利用循环编写简易ATM取款机程序能力运算符语句综合案例运算符算术运算符数字是用来计算的,比如:乘法*、除法/、加法+、减法-等等,所以经常和算术运算符一起。算术运算符:也叫数学运算符,主要包括加、减、乘、除、取余(求模)等

易基因|ONT:三代原核甲基化在痤疮杆菌噬菌体表观遗传印迹中的工程选择性研究

大家好,这里是专注表观组学十余年,领跑多组学科研服务的易基因。痤疮表皮杆菌(Cutibacteriumacnes,C.acnes)是一种革兰氏阳性细菌,是人类皮肤微生物组成员。尽管是最丰富的皮肤共生体,但某些成员与常见的炎症性疾病(如痤疮)有关。各种C.acnes分支的完整基因组序列可以鉴定推定的甲基转移酶,其中一些可

如何用CRM软件系统提升销售成绩

现如今,不少企业通过办公软件优化业务效率,加强销售管理。其中CRM销售管理系统能够有效提升销售人员的工作效率,提高销售成功率。为什么CRM系统能够提升销售业绩?下面小编从三个方面来概括说一下:为什么CRM系统能够提升销售业绩?1、CRM系统帮助企业建立“以客户为中心”的商业策略。传统企业大多是“以产品为中心,只管推出产

群晖 Docker版qbittorrent 下载显示错误 解决方法

这些天在折腾AIO玩,PVE虚拟机底层,核显直通,群晖安装,免不了踩些坑。今天写篇博客,讲述一下群晖Docker版qbittorrent下载显示错误的解决方法,顺便记录一下配置,以便日后折腾可以参考。直接说结论如果下载显示错误,并且由于自己更改了存储路径,那多半是由于权限设置。去相关的文件夹中添加Owner用户的完全控

透过《眼睛的故事》:需求为何成为纪录片的“价值锚点”?

我们正处在一个内容过载、追求流量的时代。对于观众来说,这是幸运的,也是不幸的。一方面,相比以前能接受到的内容指数级增长,自己的视野无限扩大,但另一方面,“流量思维”下粗制滥制的内容不在少数,对观众来说极其不友好。在内容极为丰盛的时代,观众越来越占主导地位。早在1935年,诺贝尔经济学奖得主哈耶克就提出了“soverei

springboot 调用第三方接口的方式(一)使用RestTemplate方法

简介常用的调用第三方接口的方式:方式一:使用RestTemplate方法方式二:使用原始httpClient请求方式三:使用Feign进行消费通过HTTPClient进行访问第三方接口。但是过程比较复杂,Feign比较适合在springCLoud多模块项目中使用,所以平时基本都是使用RestTemplate方式,这样比

如何使用正则表达式实现Java日志信息的抓取与收集

首先,什么是Java日志信息?简单来说,Java应用程序在运行过程中会输出一些信息,这些信息可以用来追踪程序运行状态、调试错误等。而Java日志信息就是这些输出信息的集合。那么为什么要抓取和收集Java日志信息呢?一方面,这些信息可以帮助我们更好地了解程序的运行情况,及时发现和解决问题;另一方面,对于大型应用程序来说,

Leetcode 01-算法入门与数组-③数组排序

LeetCode01-算法入门与数组-③数组排序一.冒泡排序1.冒泡排序算法思想冒泡排序(BubbleSort)基本思想:经过多次迭代,通过相邻元素之间的比较与交换,使值较小的元素逐步从后面移到前面,值较大的元素从前面移到后面。这个过程就像水底的气泡一样从底部向上「冒泡」到水面,这也是冒泡排序法名字的由来。接下来,我们

打破JSON的束缚:探寻Spring @JsonComponent的灵活性和扩展性

文章首发地址在Spring框架中,@JsonComponent注解用于自定义JSON序列化和反序列化的组件。它可以将一个类标记为一个Json组件,然后在对象的序列化和反序列化过程中,使用自定义的方式来处理JSON数据。使用@JsonComponent注解,需要创建一个类,并使用其中的@JsonComponent注解进行

使用 docker buildx 构建跨平台镜像 (QEMU/buildx/build)

目录1.使用buildx构建跨平台镜像1.1.简介1.2.安装1.3.构建跨平台镜像1.4.跨平台镜像构建策略1.4.1.在内核中使用QEMU仿真支持1.4.2.使用相同的构建器实例在多个本机节点上构建。1.4.3.使用Dockerfile中的多阶段构建,交叉编译到不同的平台架构中。1.5.创建builder1.6.启

热文推荐