【C++】`->` 符号

-> 符号在 C++ 中被称为成员访问运算符(Member Access Operator)。它用于访问类的成员变量或成员函数,特别是在指针的情况下。

具体用法

1. 访问类的成员变量

假设有一个类 ListNode

cpp 复制代码
class ListNode {
public:
    int val;
    ListNode* next;
    ListNode(int x) : val(x), next(nullptr) {}
};

如果你有一个指向 ListNode 的指针 node,你可以使用 -> 访问其成员变量:

cpp 复制代码
ListNode* node = new ListNode(5);
node->val = 10;  // 使用 -> 访问并修改 val 成员变量

在这个例子中,node->val 等价于 (*node).val,但 -> 更简洁和常用。

2. 访问类的成员函数

假设 ListNode 类有一个成员函数 printVal

cpp 复制代码
class ListNode {
public:
    int val;
    ListNode* next;
    ListNode(int x) : val(x), next(nullptr) {}

    void printVal() {
        std::cout << "Value: " << val << std::endl;
    }
};

你可以使用 -> 调用该成员函数:

cpp 复制代码
ListNode* node = new ListNode(5);
node->printVal();  // 使用 -> 调用 printVal 成员函数

在这个例子中,node->printVal() 等价于 (*node).printVal(),但 -> 更简洁和常用。

示例代码分析

在你的代码中,-> 符号被广泛使用,以下是一些具体的例子:

1. 在 mergeSort 函数中
cpp 复制代码
ListNode* mergeSort(ListNode *head) {
    if (!head || !head->next) return head;
    // ...
    pre_slow->next = NULL;
    // ...
    ListNode *l1 = mergeSort(head);
    ListNode *l2 = mergeSort(slow);
    // ...
}
  • head->next 用于判断链表中是否有至少两个节点。
  • pre_slow->next = NULL; 用于断开链表,使其分成两部分。
2. 在 merge2SortedLists 函数中
cpp 复制代码
ListNode* merge2SortedLists(ListNode *l1, ListNode *l2) {
    ListNode *head = new ListNode(0), *p = head;
    while (l1 && l2) {
        if (l1->val <= l2->val) {
            p->next = l1;
            p = p->next;
            l1 = l1->next;
        } else {
            p->next = l2;
            p = p->next;
            l2 = l2->next;
        }
    }
    // ...
}
  • l1->vall2->val 用于比较两个链表当前节点的值。
  • p->next = l1p->next = l2 用于将较小的节点链接到新链表中。
  • l1 = l1->nextl2 = l2->next 用于移动指针到下一个节点。

总结

-> 符号在 C++ 中用于通过指针访问类的成员变量和成员函数。它在链表操作中尤为常见,因为它简洁且直观。通过使用 ->,你可以方便地访问和操作链表中的节点及其成员。

相关推荐
liuyao_xianhui9 分钟前
优选算法_判断字符是否唯一_C++
java·开发语言·数据结构·c++·算法·链表
Yupureki16 分钟前
《C++实战项目-高并发内存池》7.大块内存的申请与释放
服务器·c语言·开发语言·c++·算法·哈希算法
2301_8035545217 分钟前
c++中的CAS是什么
java·开发语言·c++
2401_8898846623 分钟前
模板代码模块化设计
开发语言·c++·算法
Trouvaille ~24 分钟前
【贪心算法】专题(五):逆向思维与区间重叠的极致拉扯
c++·算法·leetcode·青少年编程·面试·贪心算法·蓝桥杯
marsh020626 分钟前
7 OpenClaw工作流程详解:从请求到响应的完整生命周期
网络·ai·编程·技术
2401_8980751233 分钟前
代码生成器优化策略
开发语言·c++·算法
知无不研37 分钟前
共享内存(Shared Memory)深度全解:Linux高性能IPC的核心机制与实战
linux·运维·c++·共享内存·共享内存与互斥锁
会员果汁1 小时前
网络工程-地址
网络
qq_283720051 小时前
WebGL基础教程(十四):网络图片纹理映射渲染完整实战(新手也能轻松上手)
网络·webgl