const应用

最近学校的花开了,选了一张三号楼窗前的白玉兰,(#^.^#)

1.修饰普通变量

const 用于修饰普通变量时,该变量的值在初始化之后就不能再改变。

cpp 复制代码
#include <stdio.h>

int main() {
    const int num = 10;
    // num = 20;  // 错误,不能修改常量的值
    printf("num 的值是: %d\n", num);
    return 0;
}

2.修饰数组

const修饰数组时,数组元素的值不能够被修改

cpp 复制代码
#include <stdio.h>

int main() {
    const int arr[3] = {1, 2, 3};
    // arr[0] = 10;  // 错误,不能修改常量数组元素的值
    for (int i = 0; i < 3; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
    return 0;
}

3.修饰指针

3.1 常量指针

指针指向的内容不能被修改,但指针本身可以指向其他地方。

cpp 复制代码
#include <stdio.h>

int main() {
    int num1 = 10;
    int num2 = 20;
    const int *ptr = &num1;
    // *ptr = 30;  // 错误,不能通过指针修改指向的内容
    ptr = &num2;  // 正确,指针可以指向其他地方
    printf("ptr 指向的值是: %d\n", *ptr);
    return 0;
}

在这个例子里,ptr 是一个常量指针,不能通过 *ptr 来修改其指向的值,但可以让 ptr 指向其他变量。

3.2 指针常量

指针本身的值不能被修改,但可以修改指针指向的内容。

cpp 复制代码
#include <stdio.h>

int main() {
    int num1 = 10;
    int num2 = 20;
    int *const ptr = &num1;
    *ptr = 30;  // 正确,可以修改指针指向的内容
    // ptr = &num2;  // 错误,不能修改指针本身的值
    printf("ptr 指向的值是: %d\n", *ptr);
    return 0;
}

在这段代码中,ptr 是一个指针常量,不能让 ptr 指向其他变量,但可以通过 *ptr 修改其指向的值。

4.修饰函数参数

在函数参数中使用 const,可以防止函数内部修改传入的参数值

cpp 复制代码
#include <stdio.h>

void printValue(const int num) {
    // num = 20;  // 错误,不能修改常量参数的值
    printf("传入的值是: %d\n", num);
}

int main() {
    int num = 10;
    printValue(num);
    return 0;
}

这里,printValue 函数的参数 numconst 修饰,在函数内部无法修改 num 的值。

5.修饰函数返回值

使用 const 修饰函数返回值,可让返回值成为只读的

cpp 复制代码
#include <stdio.h>

const int getValue() {
    return 10;
}

int main() {
    const int result = getValue();
    // result = 20;  // 错误,不能修改常量的值
    printf("返回的值是: %d\n", result);
    return 0;
}

在这个例子中,getValue 函数返回一个 const 类型的值,将其赋给 result 后,不能再对 result 进行修改。

相关推荐
jinmo_C++19 分钟前
数据结构_深入理解堆(大根堆 小根堆)与优先队列:从理论到手撕实现
java·数据结构·算法
IT199543 分钟前
OpenSSL3.5.2实现SM3数据摘要生成
算法·哈希算法·散列表
Excuse_lighttime1 小时前
排序数组(快速排序算法)
java·数据结构·算法·leetcode·eclipse·排序算法
潘小安1 小时前
『译』迄今为止最强的 RAG 技术?Anthropic 的上下文检索与混合搜索
算法·llm·claude
kessy11 小时前
安全与续航兼备的“国密芯”——LKT6810U
算法
leo__5202 小时前
基于经验模态分解的去趋势波动分析(EMD-DFA)方法
人工智能·算法·机器学习
lzptouch2 小时前
AdaBoost(Adaptive Boosting)算法
算法·集成学习·boosting
南方的狮子先生2 小时前
【数据结构】(C++数据结构)查找算法与排序算法详解
数据结构·c++·学习·算法·排序算法·1024程序员节
前进的李工2 小时前
LeetCode hot100:560 和为k的子数组:快速统计法
python·算法·leetcode·前缀和·哈希表
在等晚安么3 小时前
力扣面试经典150题打卡
java·数据结构·算法·leetcode·面试·贪心算法