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

相关文章

python通过curl实现访问deepseek的API

《python通过curl实现访问deepseek的API》这篇文章主要为大家详细介绍了python如何通过curl实现访问deepseek的API,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编... API申请和充值下面是deepeek的API网站https://platform.deepsee

C++类和对象之初始化列表的使用方式

《C++类和对象之初始化列表的使用方式》:本文主要介绍C++类和对象之初始化列表的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C++初始化列表详解:性能优化与正确实践什么是初始化列表?初始化列表的三大核心作用1. 性能优化:避免不必要的赋值操作2. 强

C++迭代器失效的避坑指南

《C++迭代器失效的避坑指南》在C++中,迭代器(iterator)是一种类似指针的对象,用于遍历STL容器(如vector、list、map等),迭代器失效是指在对容器进行某些操作后... 目录1. 什么是迭代器失效?2. 哪些操作会导致迭代器失效?2.1 vector 的插入操作(push_back,

Java对接Dify API接口的完整流程

《Java对接DifyAPI接口的完整流程》Dify是一款AI应用开发平台,提供多种自然语言处理能力,通过调用Dify开放API,开发者可以快速集成智能对话、文本生成等功能到自己的Java应用中,本... 目录Java对接Dify API接口完整指南一、Dify API简介二、准备工作三、基础对接实现1.

一文详解如何在Vue3中封装API请求

《一文详解如何在Vue3中封装API请求》在现代前端开发中,API请求是不可避免的一部分,尤其是与后端交互时,下面我们来看看如何在Vue3项目中封装API请求,让你在实现功能时更加高效吧... 目录为什么要封装API请求1. vue 3项目结构2. 安装axIOS3. 创建API封装模块4. 封装API请求

Python+Tkinter实现Windows Hosts文件编辑管理工具

《Python+Tkinter实现WindowsHosts文件编辑管理工具》在日常开发和网络调试或科学上网场景中,Hosts文件修改是每个开发者都绕不开的必修课,本文将完整解析一个基于Python... 目录一、前言:为什么我们需要专业的Hosts管理工具二、工具核心功能全景图2.1 基础功能模块2.2 进

Python+PyQt5开发一个Windows电脑启动项管理神器

《Python+PyQt5开发一个Windows电脑启动项管理神器》:本文主要介绍如何使用PyQt5开发一款颜值与功能并存的Windows启动项管理工具,不仅能查看/删除现有启动项,还能智能添加新... 目录开篇:为什么我们需要启动项管理工具功能全景图核心技术解析1. Windows注册表操作2. 启动文件

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

Windows系统宽带限制如何解除?

《Windows系统宽带限制如何解除?》有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文就跟大家一起来看看Windows系统解除网络限制的操作方法吧... 有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti