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

相关推荐
yourkin66635 分钟前
TCP...
服务器·网络·tcp/ip
cookies_s_s1 小时前
Linux--进程(进程虚拟地址空间、页表、进程控制、实现简易shell)
linux·运维·服务器·数据结构·c++·算法·哈希算法
不想编程小谭2 小时前
力扣LeetCode: 2506 统计相似字符串对的数目
c++·算法·leetcode
曼巴UE53 小时前
UE5.3 C++ TArray系列(一)
开发语言·c++·ue5
阿巴~阿巴~3 小时前
多源 BFS 算法详解:从原理到实现,高效解决多源最短路问题
开发语言·数据结构·c++·算法·宽度优先
ktkiko113 小时前
Websocket——心跳检测
网络·websocket·网络协议
GGGGGGGGGGGGGG.4 小时前
hapxory-ACL基础介绍及案例
运维·服务器·网络
CoderCodingNo4 小时前
【GESP】C++二级真题 luogu-b3924, [GESP202312 二级] 小杨的H字矩阵
java·c++·矩阵
刃神太酷啦5 小时前
堆和priority_queue
数据结构·c++·蓝桥杯c++组
Heris995 小时前
2.22 c++练习【operator运算符重载、封装消息队列、封装信号灯集】
开发语言·c++