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

相关推荐
cpp_250112 小时前
P1765 手机
数据结构·c++·算法·题解·洛谷
BINGCHN12 小时前
流量分析入门(二):wireshark的使用
网络·测试工具·wireshark
未到结局,焉知生死12 小时前
PAT每日三题11-20
c++·算法
桃花岛主7012 小时前
multipart/form-data 和 application/x-www-form-urlencoded区别
服务器·网络·网络协议·http
就是ping不通的蛋黄派13 小时前
数据结构与算法—线性表(C++描述)
数据结构·c++
im_AMBER13 小时前
计网 01 WebSocket | MDN
网络·websocket·网络协议
沐浴露z13 小时前
一张思维导图理清【操作系统】
java·linux·网络
杜子不疼.15 小时前
【C++】深入解析AVL树:平衡搜索树的核心概念与实现
android·c++·算法
永远不打烊15 小时前
c++11 之 统一初始化(Uniform Initalization)
c++·程序员
艾莉丝努力练剑15 小时前
【C++:哈希表封装】用哈希表封装unordered_map和unordered_set
java·c++·stl·哈希算法·散列表·平衡二叉树·哈希