【C语言干货】野指针

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


前言


提示:以下是本篇文章正文内容,下面案例可供参考

一、什么是野指针?

野指针是指向"无效内存区域"的指针。这些指针可能指向:

  • 已经释放的内存

  • 未初始化的随机地址

  • 超出合法范围的地址

使用野指针就像在现实生活中使用一个错误的地址去寄信------你无法预测信会送到哪里,甚至可能造成严重的后果。

二、野指针的三大成因

1.指针未初始化

问题代码

c

复制

下载

复制代码
#include <stdio.h>

int main() {
    int *p;  // 未初始化的局部指针变量,值是随机的
    *p = 10; // 向未知内存写入数据,危险!
    return 0;
}

分析

  • 局部变量未初始化时,其值是随机的(栈上的垃圾值)

  • 这个随机值被当作内存地址使用

  • 对该地址的读写操作可能导致段错误(Segmentation Fault)或悄无声息地破坏其他数据

2.指针越界访问

复制代码
#include <stdio.h>

int main() {
    int arr[5] = {1, 2, 3, 4, 5};
    int *p = arr;
    
    for(int i = 0; i <= 5; i++) {  // 故意越界
        *(p++) = i * 10;
    }
    
    return 0;
}

分析

  • 数组arr只有5个元素,有效索引是0-4

  • 循环访问了arr[5],这已经越界

  • 越界后p指向的内存可能属于其他变量或不可访问区域

  • 可能破坏栈上的其他数据(如返回地址),导致程序异常

3. 指针指向已释放的内存

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

int *create_array(int size) {
    int *arr = (int *)malloc(size * sizeof(int));
    for(int i = 0; i < size; i++) {
        arr[i] = i + 1;
    }
    return arr;
}

int main() {
    int *my_array = create_array(5);
    free(my_array);  // 内存已释放
    
    // 错误:使用已释放的内存
    printf("%d\n", my_array[2]);  
    
    return 0;
}

分析

  • free()释放了my_array指向的内存

  • 但my_array的值(地址)并未改变

  • 继续使用这个指针就是访问已释放的内存

  • 可能导致数据混乱、程序崩溃或安全漏洞


相关推荐
Rust语言中文社区4 分钟前
【Rust日报】 walrus:分布式消息流平台,比 Kafka 快
开发语言·分布式·后端·rust·kafka
全栈视界师6 分钟前
《机器人实践开发②:Foxglove 嵌入式移植 + CMake 集成》
c++·机器人·数据可视化
多多*9 分钟前
Threadlocal深度解析 为什么key是弱引用 value是强引用
java·开发语言·网络·jvm·网络协议·tcp/ip·mybatis
Python×CATIA工业智造10 分钟前
Python多进程爬虫实战:豆瓣读书数据采集与法律合规指南
开发语言·爬虫·python
一只乔哇噻17 分钟前
java后端工程师+AI大模型进修ing(研一版‖day56)
java·开发语言·学习·算法·语言模型
美团测试工程师18 分钟前
软件测试面试题2025年末总结
开发语言·python·测试工具
小熳芋24 分钟前
排序链表- python-非进阶做法
数据结构·算法·链表
繁华似锦respect27 分钟前
Linux-内核核心组成部分
linux·c++
F***741727 分钟前
PHP操作redis
开发语言·redis·php
zore_c32 分钟前
【C语言】数据在内存中的存储(超详解)
c语言·开发语言·数据结构·经验分享·笔记