C++ Windows API CreateFile

2024-08-31 08:04
文章标签 c++ windows api createfile

本文主要是介绍C++ Windows API CreateFile,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

本文介绍windows提供的 打开文件或创建的系统接口-----CreateFile().
开发中,时常有打开文件的需求,日常我们使用的是c++标准库内的ofstream和ifstream来进行文件的创建、读写。但是Windows系统本身也为我们提供了相关的接口。

内容

CreateFime函数原型

HANDLE CreateFile( 
LPCTSTR lpFileName, // 文件名或路径 
DWORD dwDesiredAccess, // 访问权限 
DWORD dwShareMode, // 共享模式 
LPSECURITY_ATTRIBUTES lpSecurityAttributes, // 安全属性 
DWORD dwCreationDisposition, // 创建方式 
DWORD dwFlagsAndAttributes, // 文件属性 
HANDLE hTemplateFile // 模板文件句柄 
);

参数说明

  • lpFileName:要创建或打开的文件名或路径。可以是相对路径、绝对路径或网络路径。支持一些特殊符号,如“.”表示当前目录,“…”表示上级目录。
  • dwDesiredAccess:指定对文件的访问权限。常用的值包括GENERIC_READ(读取权限)、GENERIC_WRITE(写入权限)、GENERIC_EXECUTE(执行权限)和GENERIC_ALL(所有权限)。
  • dwShareMode:指定文件共享模式。可以指定其他进程是否可以读取、写入或删除该文件。常用的值包括FILE_SHARE_READ(允许其他进程读取)、FILE_SHARE_WRITE(允许其他进程写入)和FILE_SHARE_DELETE(允许其他进程删除)。
  • lpSecurityAttributes:指向SECURITY_ATTRIBUTES结构的指针,用于指定文件的安全属性。如果设置为NULL,则使用默认的安全属性。
  • dwCreationDisposition:指定文件的创建方式。如果文件已存在,则此参数决定如何打开文件;如果文件不存在,则此参数决定如何创建文件。常用的值包括CREATE_NEW(创建新文件,如果文件已存在则失败)、CREATE_ALWAYS(创建新文件,如果文件已存在则覆盖)、OPEN_EXISTING(打开已存在的文件,如果文件不存在则失败)等。
  • dwFlagsAndAttributes:指定文件的属性和标志。常用的值包括FILE_ATTRIBUTE_NORMAL(普通文件)、FILE_ATTRIBUTE_HIDDEN(隐藏文件)、FILE_ATTRIBUTE_READONLY(只读文件)等。此外,还可以指定一些高级选项,如FILE_FLAG_OVERLAPPED(允许对文件进行重叠操作)和FILE_FLAG_NO_BUFFERING(禁止对文件进行缓冲处理)等。
  • hTemplateFile:指定一个模板文件的句柄,通常设置为NULL,表示不使用模板文件。

返回值

  • 如果函数成功,返回值是文件的句柄。这个句柄是一个指向文件的指针,可以用来进行后续的读写操作。
  • 如果函数失败,返回值是INVALID_HANDLE_VALUE。在这种情况下,可以使用GetLastError函数来获取错误代码。

示例代码

    HANDLE hFile = CreateFile(  L"C:\\example\\test.txt", // 文件名或路径  GENERIC_READ | GENERIC_WRITE, // 访问权限  FILE_SHARE_READ, // 共享模式  NULL, // 安全属性  CREATE_ALWAYS, // 创建方式  FILE_ATTRIBUTE_NORMAL, // 文件属性  NULL // 模板文件句柄  );  if (hFile == INVALID_HANDLE_VALUE) {  // 处理文件打开失败的情况  } else {  // 成功打开文件后的操作  // 关闭文件句柄  CloseHandle(hFile);  }  

注意事项

  1. 在使用CreateFile函数时,需要确保文件名或路径是有效的,并且应用程序具有对指定文件或目录的适当访问权限。(路径分为相对路径和绝对路径)
  2. 打开文件后,应使用CloseHandle函数关闭文件句柄,以释放系统资源。
  3. 如果在调用CreateFile函数时遇到错误,可以通过GetLastError函数获取具体的错误代码,并根据错误代码进行相应的错误处理。建议进行必要的错误处理,以减少BUG.

参考

参考内容:百度文言一心

这篇关于C++ Windows API CreateFile的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1123333

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据

Python用Flask封装API及调用详解

《Python用Flask封装API及调用详解》本文介绍Flask的优势(轻量、灵活、易扩展),对比GET/POST表单/JSON请求方式,涵盖错误处理、开发建议及生产环境部署注意事项... 目录一、Flask的优势一、基础设置二、GET请求方式服务端代码客户端调用三、POST表单方式服务端代码客户端调用四

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

SpringBoot结合Knife4j进行API分组授权管理配置详解

《SpringBoot结合Knife4j进行API分组授权管理配置详解》在现代的微服务架构中,API文档和授权管理是不可或缺的一部分,本文将介绍如何在SpringBoot应用中集成Knife4j,并进... 目录环境准备配置 Swagger配置 Swagger OpenAPI自定义 Swagger UI 底