c语言文件清空truncate ftruncate函数

2024-05-30 01:18

本文主要是介绍c语言文件清空truncate ftruncate函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

truncate ftruncate函数

  truncate()和ftruncate()都可以用来修改文件大小,但两者之间也有一些区别。

一、truncate()函数

头文件:

#include <unistd.h>

函数定义:

int truncate(const char *path, off_t length);

函数调用:

truncate("./test.txt", 500);

函数说明:

  truncate()会将参数path指定的文件大小改为参数length指定的大小。 如果原来的文件大小比参数length大,则超过的部分会被删除(如需清空文件,length设置为0)

返回值:

  执行成功则返回0, 失败返回-1, 错误原因存于errno

错误代码:

1 EACCESS 参数path所指定的文件无法存取 
2 EROFS 欲写入的文件存在于只读文件系统内 
3 EFAULT 参数path指针超出可存取空间 
4 EINVAL 参数path包含不合法字符 
5 ENAMETOOLONG 参数path太长 
6 ENOTDIR 参数path路径并非一目录 
7 EISDIR 参数path指向一目录 
8 ETXTBUSY 参数path所指的文件为共享程序,而且正被执行中 
9 ELOOP 参数path 有过多符号连接问题。 
10 EIO I/O存取错误

二、ftruncate()函数

头文件:

#include<unistd.h>

函数定义:

int ftruncate(int fd,off_t length);

函数调用:

1 out = open("./test.txt", O_RDWR | O_CREAT, S_IRUSR); 
2 ftruncate(out, 500); 
3 close(out);

函数说明:

  ftruncate()会将参数fd指定的文件大小改为参数length指定的大小。

  参数fd为已打开的文件描述词,而且必须是以写入模式打开的文件。

  如果原来的文件大小比参数length大,则超过的部分会被删去。(如需清空文件,length设置为0)

返回值:

  执行成功则返回0,失败返回-1,错误原因存于errno。

错误代码:

1 EBADF 参数fd文件描述词为无效的或该文件已关闭。 
2 EINVAL 参数fd 为一socket 并非文件,或是该文件并非以写入模式打开。

三、例如

int fd;
const char *s1 = "0123456789";
const char *s2 = "abcde";
fd = open("test.txt", O_CREAT | O_WRONLY | O_TRUNC, 0666);
write(fd, s1, strlen(s1));ftruncate(fd, 0);
lseek(fd, 0, SEEK_SET);write(fd, s2, strlen(s2));
close(fd);
return 0;//先清空文件,再设置文件偏移量,否则会产生文件空洞
ftruncate(fd, 0); 
lseek(fd, 0, SEEK_SET); 

 

这篇关于c语言文件清空truncate ftruncate函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

Go语言中make和new的区别及说明

《Go语言中make和new的区别及说明》:本文主要介绍Go语言中make和new的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1 概述2 new 函数2.1 功能2.2 语法2.3 初始化案例3 make 函数3.1 功能3.2 语法3.3 初始化

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁