C++(五) access函数判断文件是否存在
最近看到一个函数,第一觉得很sb,因为remove的定义在if内部,变成了局部变量,结果如果文件“234.bin”不存在的话,一定会出错的,因为remove的生存期有限。 结果,亮瞎我的: #includeiostream#include unistd.h#include stdio.h#include stdlib.husing na
最近看到一个函数,第一眼觉得很sb,因为remove的定义在if内部,变成了局部变量,结果如果文件“234.bin”不存在的话,一定会出错的,因为remove的生存期有限。
结果,亮瞎我的眼:
#include<iostream> #include "unistd.h" #include "stdio.h" #include "stdlib.h" using namespace std; int main() { if(access("234.bin",F_OK)) { bool remove=true; } if(remove) { cout<strong>结果各种悲剧,无论这个文件是否存在:</strong> <p><img src="/static/imghw/default1.png" data-src="/inc/test.jsp?url=http%3A%2F%2Fmy.csdn.net%2Fuploads%2F201206%2F07%2F1339078989_9217.jpg&refer=http%3A%2F%2Fblog.csdn.net%2Femaste_r%2Farticle%2Fdetails%2F7643479" class="lazy" alt="C++(五) access函数判断文件是否存在" ></p> <p><br> </p> <p>事实上,我个人认为这个问题出在这个access函数的返回值上,它的返回值是</p> <p>0 如果文件是指定的mode<br> </p> <p>-1 如果出错</p> <p>所以上述程序,无论是找到文件(0),还是找不到(-1),都是false,所以应该是永远都进不了if(remove)的。。<br> </p> <p>所以应该是:</p> <pre class="brush:php;toolbar:false">if(0 == access("234.bin",F_OK)) { remove = true; }
原来:
remove是一个已经存在的函数,函数地址不为空,所以一直都能进 if(remove){}
大家,以后判断文件是否存在,用以下的代码比较好:
#include<iostream> #include "unistd.h" #include "stdio.h" #include "stdlib.h" using namespace std; int file_exist(char *file) { return (access(file,F_OK) == 0); } int main() { cout<strong>总结:</strong> <p>(一)用access函数注意返回值是 0 和-1,都是false<br> </p> <p>(二)remove是个函数名,定义命名的时候注意不要用到系统的东东<br> </p> <br> </iostream>

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

DeepSeek 无法直接将文件转换为 PDF。根据文件类型,可以使用不同方法:常见文档(Word、Excel、PowerPoint):使用微软 Office、LibreOffice 等软件导出为 PDF。图片:使用图片查看器或图像处理软件保存为 PDF。网页:使用浏览器“打印成 PDF”功能或专用的网页转 PDF 工具。不常见格式:找到合适的转换器,将其转换为 PDF。选择合适的工具并根据实际情况制定方案至关重要。

策略模式在C++中的实现步骤如下:定义策略接口,声明需要执行的方法。创建具体策略类,分别实现该接口并提供不同的算法。使用上下文类持有具体策略类的引用,并通过它执行操作。

Golang和C++分别是垃圾回收和手动内存管理编程语言,语法和类型系统各异。Golang通过Goroutine实现并发编程,C++通过线程实现。Golang内存管理简单,C++性能更强。实战案例中,Golang代码更简洁,C++性能优势明显。

嵌套异常处理在C++中通过嵌套的try-catch块实现,允许在异常处理程序中引发新异常。嵌套的try-catch步骤如下:1.外部try-catch块处理所有异常,包括内部异常处理程序抛出的异常。2.内部try-catch块处理特定类型的异常,如果发生超出范围的异常,则将控制权交给外部异常处理程序。

要遍历STL容器,可以使用容器的begin()和end()函数获取迭代器范围:向量:使用for循环遍历迭代器范围。链表:使用next()成员函数遍历链表元素。映射:获取键值对迭代器,使用for循环遍历。

C++模板继承允许模板派生类重用基类模板的代码和功能,适用于创建具有相同核心逻辑但不同特定行为的类。模板继承语法为:templateclassDerived:publicBase{}。实例:templateclassBase{};templateclassDerived:publicBase{};。实战案例:创建了派生类Derived,继承了基类Base的计数功能,并增加了printCount方法来打印当前计数。

C++模板在实际开发中广泛应用,包括容器类模板、算法模板、泛型函数模板和元编程模板。例如,泛型排序算法可对不同类型数据的数组进行排序。

在多线程C++中,异常处理通过std::promise和std::future机制实现:在抛出异常的线程中使用promise对象记录异常。在接收异常的线程中使用future对象检查异常。实战案例展示了如何使用promise和future在不同线程中捕获和处理异常。
