Linux C/C++编程:对文件操作的封装

1059 篇文章 275 订阅

源码

//
// Created by oceanstar on 2021/8/9.
//

#ifndef OCEANSTAR_HTTP_ACL_FILE_H
#define OCEANSTAR_HTTP_ACL_FILE_H

#include <global.h>
#include "acl_vstream.h"

#define  acl_off_t long long int
# define	ACL_FILE_HANDLE		int
namespace oceanstar{

    class acl_file{
    private:
        ACL_FILE_HANDLE file_handle_;
        explicit acl_file(ACL_FILE_HANDLE file_handle){
            file_handle_ = file_handle;
        }
    public:


        /**
          * 打开文件句柄
          * @param filepath {cosnt char*} 文件路径
          * @param flags {int} 打开标志位, O_RDONLY | O_WRONLY | O_RDWR,
          *  O_CREAT | O_EXCL | O_TRUNC, O_APPEND(for UNIX)
          * @param mode {int} 打开权限位, 仅对UNIX有效, 如:0700, 0755
          * @return {ACL_FILE_HANDLE} 打开的文件句柄,返回 ACL_FILE_INVALID 表示打开失败
          */
        static acl_file* acl_file_open(const char *filepath, int flags, int mode);
        /**
         * 关闭打开的文件句柄
         * @return {int} 0: ok; -1: error
         */
         int acl_file_close();
        /**
        * 定位文件位置
        * @param fh {ACL_FILE_HANDLE} 文件句柄
        * @param offset {acl_off_t} 偏移位置
        * @param whence {int} 位置标志位:SEEK_CUR, SEEK_SET, SEEK_END
        * @return {acl_off_t} 当前的文件偏移位置
        */
         acl_off_t acl_lseek(acl_off_t offset, int whence);
        /**
        * 从文件中读数据
        * @param fh {ACL_FILE_HANDLE} 文件句柄
        * @param buf {void*} 存储缓冲区
        * @param size {size_t} buf 缓冲区大小
        * @param timeout {int} 读超时时间(秒)
        * @param fp {ACL_VSTREAM*} 对应的文件流句柄, 可以为空
        * @param arg {void*} 用户传递的参数, 以回调方式使用时此参数有效
        * @return {int} 读到的实际数据, 如果返回 ACL_VSTREAM_EOF 表示读结束或出错
        */
         int acl_file_read(void *buf, size_t size,
                                  int timeout, ACL_VSTREAM *fp, void *arg);
        /**
        * 向文件中写数据
        * @param fh {ACL_FILE_HANDLE} 文件句柄
        * @param buf {void*} 数据存储缓冲区
        * @param size {size_t} buf 缓冲区中数据长度大小
        * @return {int} 成功写的数据量, 如果返回 ACL_VSTREAM_EOF 表示写出错
        */
         int acl_file_write(const void *buf, size_t size);

         int acl_file_lseek_begin(){
             return lseek(file_handle_, 0, SEEK_SET);
         }

        /**
         * 向文件中写一组数据
         * @param fh {ACL_FILE_HANDLE} 文件句柄
         * @param vec {const struct iovec*} 数据存储数组
         * @param count {int} vec 数组中元素个数
         * @return {int} 成功写的数据量, 如果返回 ACL_VSTREAM_EOF 表示写出错
         */
        int acl_file_writev(const struct iovec *vec, int count);
        /**
         * 将文件缓冲区中的数据全部写入硬盘
         * @return {int} 0: ok; -1: error
         */
         int acl_file_fflush();
        /**
        * 根据文件名取得该文件的大小
        * @param filename {const char*} 文件名
        * @return {acl_int64} >= 0: ok;  -1: error
        */
         acl_int64 acl_file_size(const char *filename);
        /**
        * 根据文件句柄取得该文件的大小
        * @return {acl_int64} >= 0: ok;  -1: error
        */
         acl_int64 acl_file_fsize();
    };
}
#endif //OCEANSTAR_HTTP_ACL_FILE_H

//
// Created by oceanstar on 2021/8/9.
//
#include <fcntl.h>
#include <unistd.h>
#include "acl_file.h"
#include<sys/stat.h>


namespace oceanstar{
    /**
     * 打开文件句柄
     * @param filepath {cosnt char*} 文件路径
     * @param flags {int} 打开标志位, O_RDONLY | O_WRONLY | O_RDWR,
     *  O_CREAT | O_EXCL | O_TRUNC, O_APPEND(for UNIX)
     * @param mode {int} 打开权限位, 仅对UNIX有效, 如:0700, 0755
     * @return {acl_file *} 打开的文件句柄,返回 null 表示打开失败
     */
    acl_file* acl_file::acl_file_open(const char *filepath, int flags, int mode){
        const char *myname = "acl_file_open";
        ACL_FILE_HANDLE handle =  open(filepath, flags, mode);
        if(handle == -1){
            logger_error("%s, %s(%d): open file(%s) error(%s)",
                          myname, __FILE__, __LINE__,
                          filepath, strerror(errno));
            return nullptr;
        }

        return new acl_file(handle);
    }

    int  acl_file::acl_file_close(){
        int ret = close(file_handle_);
        delete this;
        return ret;
    }

    acl_off_t acl_file::acl_lseek(acl_off_t offset, int whence){
        return lseek64(file_handle_, offset, whence);
    }

    int acl_file::acl_file_read(void *buf, size_t size,
                                int timeout, ACL_VSTREAM *fp, void *arg){
        if (fp != NULL && fp->get_read_ready()) {
            fp->set_read_ready(0);
        }
        return (int) read(file_handle_, buf, size);
    }

    int acl_file::acl_file_write(const void *buf, size_t size){
        return (int) write(file_handle_, buf, size);
    }

    int acl_file::acl_file_writev(const struct iovec *vec,
                        int count){
        return (int) writev(file_handle_, vec, count);
    }

    int acl_file::acl_file_fflush(){
        return fsync(file_handle_);
    }

    /**
        * 根据文件名取得该文件的大小
        * @param filename {const char*} 文件名
        * @return {acl_int64} >= 0: ok;  -1: error
        */
    acl_int64 acl_file::acl_file_size(const char *filename){
        struct stat sbuf;

        if (stat(filename, &sbuf) == -1) {
            return -1;
        }
        return sbuf.st_size;
    }

        /**
        * 根据文件句柄取得该文件的大小
        * @return {acl_int64} >= 0: ok;  -1: error
        */
     acl_int64 acl_file::acl_file_fsize(){
        struct stat sbuf;

        if (fstat(file_handle_, &sbuf) == -1) {
            return -1;
        }
        return sbuf.st_size;
    }
}



测试

#include "acl_file.h"

int main(void){
    oceanstar::acl_file * fh = oceanstar::acl_file::acl_file_open("text.txt",  O_CREAT | O_RDWR | O_APPEND, 0755);
    if(fh == NULL){
        printf("open text.txt error [%s]\n", strerror(errno));
        exit(0);
    }

    printf("file_size = %lld\n", fh->acl_file_fsize());

    int ret ;
    char  buf[1024];
    memset(buf, 0, strlen(buf));
    sprintf(buf, "hello client");
    ret = fh->acl_file_write(buf, strlen(buf));
    if(ret == ACL_VSTREAM_EOF){
        printf("write to file error [%s]\n", strerror(errno));
        fh->acl_file_close();
        exit(0);
    }
    printf("write to file ok [%d]\n", ret);

    memset(buf, 0, strlen(buf));

    //记住,这里一定要重新打开或者lseek到开头,否则读不到数据【因为当前文件指针已经定位到了最末尾】
    fh->acl_file_lseek_begin();

    int ret1 = fh->acl_file_read(buf, sizeof(buf), 0, NULL, 0);
    if (ret1 == ACL_VSTREAM_EOF) {
        printf("read to file error [%s]\n", strerror(errno));
        fh->acl_file_close();
        exit(0);
    }
    buf[ret1] = 0;
    printf("acl_file_read = [%d: %s]\n",  ret1, buf);

    fh->acl_file_close();
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux C/C++后台架构开发是一门非常具有前景的技能,在互联网和各种电子设备中都得到广泛应用。因此,这门课程的成长体系很重要,能够立足于现有技术发展趋势,不断完善内容,使学员能够跟随市场需求进行技术升级。 首先,课程应该注重基础知识的讲解,包括Linux操作系统的基础知识、C/C++编程语言的基础知识等,这是后续学习的基础。其次,应该注重实战训练,通过项目的实践来加深对知识的理解,并促进学员的技能提升。同时,要合理结合课程的理论知识和实践操作,培养学员的动手能力和实际应用技能。 除此之外,课程还应该关注行业技术变化的趋势,不断更新课程内容,讲解新技术的应用,使学员能够跟随技术的发展趋势提升自己。同时,要注重培养学员的团队合作能力和创新能力,帮助他们更好地适应团队工作和市场需求。 总之,Linux C/C++后台架构开发成长体系课程需要注重基础知识的讲解、实战训练、行业技术变化的跟进和团队合作与创新能力的培养。通过这些方面的努力,才能使学员掌握实用的技术,具备市场竞争力,并有能力适应未来技术的发展趋势。 ### 回答2: 作为一种开源的操作系统,Linux的应用广泛,尤其在服务器端,被广泛应用于Web服务器、数据库服务器等。因此,当今各大企业都需要专业的Linux后台架构开发人员来维护服务器的安全、稳定和高效运行。 而C/C++作为一种高效、可靠的编程语言,被广泛应用于Linux系统编程,尤其是在高性能、实时应用和底层驱动方面。因此,具备C/C++编程能力的Linux后台架构开发人员具有较高的市场竞争力。 在成长体系课程方面,专业的培训机构可以提供基础和高级的C/C++编程语言学习,以及Linux系统编程相关知识扎实的培训。而在课程设置和教学方式上,应该采取理论与实践相结合的方式,让学员在编程实践中逐渐掌握并理解相关知识。同时,在应用开发的过程中,特别是在搭建后台架构时,需要学会合理设计系统架构,选择合适的开发工具和技术,并能有效管理和维护系统。 此外,针对行业发展趋势和技术更新,培训机构应当不断更新课程内容,结合最新的技术趋势,为学员提供更具有竞争力的技术挑战,并开展多种实战项目实践。让学员在实践中提升自己的技能和实践经验,不断提升自身的职业竞争力。 ### 回答3: Linux C/C++后台架构开发是一个广受欢迎的领域,无论是大型互联网企业还是中小型企业都需要有相应的开发团队和技术人才。开发人员需要具备扎实的C/C++编程基础,熟悉Linux操作系统的运行机制和性能优化,了解分布式系统架构和网络通信协议等知识,以及掌握一定的数据库开发和管理经验。 针对此领域的开发人员,成长体系课程可以提供以下培训内容: 一、Linux操作系统原理:Linux系统的运行机制,常用命令和工具的使用方法,文件系统和进程管理等。 二、C/C++编程:C/C++基础语法和编程规范,数据结构和算法,内存管理和锁机制等。 三、分布式系统架构:分布式系统的概念和架构,通信协议和数据传输方式,分布式存储和计算等。 四、网络通信:TCP/IP协议栈和网络编程,HTTP、Websocket等常用协议的使用和封装。 五、数据库开发和管理:常见数据库的概念和使用方法,SQL语言编写,数据库的设计和优化等。 通过以上培训内容的学习和实践,开发人员可以逐渐掌握Linux C/C++后台架构开发的技能和经验,不断提升能力和水平。同时,课程还将涉及团队协作和项目管理等方面的知识,培养学员的软技能和团队意识。最终,学员能够独立完成复杂的后台开发任务,为企业创造更大的价值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值