百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

满屏红色:C语言中最常见的这些报错,你经历过多少

cac55 2024-12-16 11:16 24 浏览 0 评论


相信大家在刚刚学习编程的过程中一定遇到过大片的红色吧,这些让大家看着头疼的报错却是大家成长的见证呢,这里帮大家总结一下那些经常遇到的报错。

1、FORWARD_NULL

通常发生的情况是,一个指针先被判断是否等于NULL,然后指针被非法引用。

非法引用NULL的指针会导致程序崩溃。程序员在判断指针是否等于NULL时,没能正确的处理好,或者是忘记了NULL在代码路径的情况。

2、USE_AFTER_FREE

即使用已被释放的内存、同一指针被释放多次。

当内存被释放后,就不能再被安全的使用。而同一内存的多次释放通常会导致未定义的行为,包括内存冲突和程序崩溃。

引用已释放的指针也是非常危险的,因为指针的值不确定或者指针指向任意内存的位置。

在多线程的程序中,多次释放同一内存非常危险,因为已释放的内存可能已被另一线程申请,再次释放可能导致该线程的内存也被释放,在这种情况下,该线程使用已释放的内存,可能导致紊乱,同时很难被编译器跟踪。

3、RESOURCE_LEAK

资源泄漏(内存泄漏)指变量在出了自己的作用范围后,占用的资源仍然驻守在内存里,没有被释放。

严重的内存泄漏能导致进程崩溃,即便是很小的内存泄漏,在系统长时间运行没有重启后,也会产生错误。如果内存泄漏是由用户输入或者网络数据触发,还会成为“拒绝服务攻击”的对象。

文件句柄或者网络套接字的泄漏会导致程序崩溃、拒绝服务攻击或者打开其他文件或套接字失败。操作系统通常会限制进程的文件句柄和套接字个数。当达到限制的最大值时,进程要申请新的资源时,首先要关闭一些已打开的资源。如果进程中存在资源泄漏,进程自己将没有办法回收这些资源,除非强行终止该进程。

多数情况下,这些泄漏通常发生在某个错误的路径,比如说,某个异常处理的分支。这种情况下,正确的做法应该是将程序跳转(GOTO)到该函数的出口,出口处应释放这些资源。

在C++中,RAII(the Resource Acquisition Is Initialization)机制能够自动的释放资源。RAII包括类的一个申请资源的构造函数和释放资源的析构函数。当一个类的局部变量声明后,当离开该变量的作用范围后,RAII会自动调用其析构函数释放资源,这同样也会保护throw异常导致的泄漏。

4、NULL_RETURN

函数的返回值可能是NULL,所以使用函数返回值的变量一定要首先检查是否是NULL,否则就可能出错。

程序员经常不会去检查函数的返回值,而是直接以危险的方式去使用,可能会由于对NULL的非法引用,导致程序崩溃。

5、error C2143:语法错误:缺少“;”(在“*”的前面)

该错误主要是某类型数据未include,可能是都文件拼写错误、或者头文件名已经更改、或是头文件忘记“;”

解决办法:检查头文件是否更名、是否忘记结束的“;”

6、error C1010:查找预编译头时遇到意外的文件结尾。是否忘记了向源中添加“#include "StdAfx.h”

解决办法:在报错行所在的文件的最前面添加“#include "StdAfx.h”

7、error C1189:出现了WINDOWS.H already included. MFC apps must not #include 的处理办法。

解决办法:把#include提到最前面去就可以编译成功了。

8、error LNK2005: _DllMain@12 already defined in dllmain.obj

解决办法:你只需要在工程设置里面把WIN32,NDEBUG,_WINDOWS,_MBCS,_USRDLL,MSGBOX_EXPORTS,_WINDLL,_AFXDLL

中的_USRDLL,删除,就可以正确编译了 。

编程的学习本身就是离不开报错的,就算是大牛们也会遇到报错,面对报错不要慌张,根据报错去更好的完善自己的程序,让自己的程序更加的完美,为了帮助大家更好的学习,这里也是帮助大家整理了一些c/c++相关的基础知识点资料,还有相关的项目实战讲解资料,感兴趣的可以私聊分享更多。希望大家能够在报错和不断的实践中做的更好,成功一直都是给肯坚持的人准备的。

相关推荐

远程桌面管理服务器的软件工具:Splashtop

通过远程控制和维护服务器,IT运维无需亲自在设备附近就可以轻松完成工作,极大地提高了效率。在本文中,我们将深入了解远程桌面管理服务器的主要优点,以及实现此任务所需的软件工具和操作方法。首先,远程桌面管...

最担心的事还是发生了 19岁黑客远程破解逾25台特斯拉

近日,德国19岁的安全研究人员大卫·科伦坡(DavidColombo)表示,他在特斯拉的系统中发现一处系统漏洞,并通过该漏洞远程入侵了13个国家的25辆特斯拉电动汽车,使其关闭安全系统。他几乎掌控了...

朝鲜黑客使用已知恶意软件家族FASTCash的 Linux 变种来窃取资金

据观察,朝鲜威胁组织使用已知恶意软件家族FASTCash的Linux变种来窃取资金,作为以财务为动机的活动的一部分。一位自称HaxRob的安全研究员表示,这种恶意软件“安装在受感染网络内处理卡...

Phorpiex恶意脚本卷土重来,成为LockBit 3.0勒索木马传播载体

IT之家5月5日消息,安全公司Cybereason发文透露“老牌”恶意脚本Phorpiex近日又卷土重来,成为传播LockBit3.0勒索木马的载体,感染了相应脚本的设备会自动下...

黑客远程入侵控制Jeep 自由光 互联网汽车存隐患

当我们在为汽车互联网技术带来的便捷欢呼雀跃时,也许危险也在悄悄走近。近日据Wired报道,名叫安迪的男子正开着Jeep自由光以70码的时速行驶在圣路易斯下城区时,车辆突然失去了控制。“首先是冷风突然调...

警惕!KeePass密码管理器竟成黑客“帮凶”

近日,网络安全领域爆出一则令人震惊的消息:网络安全公司WithSecure披露,在过去至少八个月的时间里,黑客通过篡改知名的KeePass密码管理器,上演了一场大规模的恶意攻击大戏!KeePass作...

开源网页应用框架ThinkPHP遭黑客滥用,变身远程代码执行工具

IT之家6月9日消息,安全公司Akamai近日发布报告,声称目前有黑客滥用一款热门开源网页应用框架ThinkPHP中的远程执行代码漏洞,打造了一款名为“Dama”的恶意工具进行攻击。I...

远程控制、窃密、挖矿!我国境内捕获“银狐”木马病毒变种

最近大家可得小心电脑病毒了!国家相关部门刚通报了一个叫"银狐"的木马病毒新变种,专门盯着普通老百姓和企事业单位下手。我给大家掰开揉碎了讲讲,遇到这种情况该怎么躲坑?·一、这病毒怎么盯上...

6款Linux常用远程连接工具,你最中意哪一款?

点击上方头像关注我,每周上午09:00准时推送,每月不定期赠送技术书籍。本文2106字,阅读约需6分钟Hi,大家好。远程连接的实现方法有很多,概括地说有两种,一种是用系统自带的远程连接,另外一种是用...

安全公司曝光黑客山寨杀毒软件Bitdefender官网,实为提供木马

IT之家5月31日消息,安全公司DomainTools发文,透露有黑客伪造网站声称提供杀毒软件,实则借机传播恶意木马。IT之家参考相应通报获悉,相应黑客首先建立山寨Bitdefender...

魔兽世界怀旧服:mc与bwl高手进阶输出手法与职业心得理解

作者:NGA-499917309a前言:之前写了两篇教新手术士怎么打mc和bwl的帖子,属于基础入门,只是让大家会打,随着时间推移,副本早已进入farm阶段,新手也不满足于会打,而是追求更高的输出,甚...

《奇幻梦境》进不去游戏解决方法攻略

奇幻梦境第一章近日发售了,本作也是一款第一人称解密游戏。本作的游戏画面色彩简单明了,包括了游戏的剧情也是。有不少的小伙伴反映奇幻梦境打不开不进不去,接下来小编就给大家解决这款游戏打不开进不去的一些可能...

国外网友热议:LOL客户端仍然如此差劲!新版又在测试了?

印象中英雄联盟的客户端换过几次版本,但是动作最大的应该就是在2017年的那次,直接更换了整个客户端的UI界面以及内部的很多组件。但是新版客户端上线至今两年多的时间里,玩家对于这个客户端的吐槽依旧很多,...

谷歌地球免费专业版7.1.5.1557下载

IT之家讯5月22日消息,谷歌地球专业版GoogleEarthPro已经更新到7.1.5.1557版,目前,谷歌官方还没有给出更新日志。这种情况通常来讲都是常规问题修复,建议新老用户及时下载安装...

僵尸部队三部曲 免安装中文硬盘版下载发布

【游戏封面】中文名称:僵尸部队三部曲游戏名称:ZombieArmytrilogy游戏类型:第三人称射击游戏制作:Rebellion游戏发行:Rebellion游戏发行:PC游民星空狙击精英3专区版...

取消回复欢迎 发表评论: