C/C++通过2019VS操作linux的open和write、read函数的用法,及其函数使用注意点

Linux中怎么挂载U盘?

要通过命令创建文件,操作文件就相当于操作硬件,因此所有设备都看成是一种特殊的文件。

移动存储都是挂载在/mnt目录下

/Opt是安装目录

三个直接对操作系统核心连接的P是系统调用,相当于是使用了系统自带的函数,比如说cd这个指令

函数库连接了操作系统核心,这个意思是函数库中的部分函数只是对操作系统自带函数的一种包装,其实本质上是系统自带函数

Linux系统和Windows系统下的printf调用的系统函数不同

内核编程是直接调用系统函数,效率更快,不需要去通过函数库比对,然后再从函数库角度去调用系统函数

调用系统函数的目的:服务器开发

函数库的优点:把开发者和使用者的平台区分开,开发是一个平台,使用是一个平台,这样就可以实现跨平台使用

系统函数:

Open

  • 函数原型

                     int open(const char *path, int flags);

  • 参数

path :文件的名称,可以包含(绝对和相对)路径

flags:文件打开模式

  • 返回值

       打开成功,返回文件描述符;

       打开失败,返回-1

---------------------------以下是open三参数--------------------------------

  • 函数原型

int open(const char *path, int flags,mode_t mode);

  • 参数

path :文件的名称,可以包含(绝对和相对)路径

flags:文件打开模式

mode:  用来规定对该文件的所有者,文件的用户组及系统中其他用户的访问权限,则文件权限为:mode&(~umask)

  • 返回值

       打开成功,返回文件描述符;

       打开失败,返回-1

--------------------------打开模式主要有以下几种----------------------------

  1. O_RDONLY 打开一个供读取的文件
  2. O_WRONLY打开一个供写入的文件
  3. O_RDWR打开一个可供读写的文件
  4. O_CREAT打开文件,如果文件不存在则建立文件
  5. O_TRUNC在open()时,将文件清空
  6. O_NONBLOCK如果路径名指向FIFO/块文件/字符文件,则把文件的打开和后继I/O设置为非阻塞模式

所有这些标志值的符号名称可以通过#include<fcntl.h0>访问

Read

  • 函数原型:

              int read(int fd, void *buf, size_t nbytes);

              参数

  • fd :想要读的文件的文件描述符
  • buf:  指向内存块的指针,从文件中读取来的字节放到这个内存块中
  • nbytes: 从该文件复制到buf中的字节个数

返回值

       如果出现错误,返回-1

       返回从该文件复制到规定的缓冲区中的字节数,文件结束,返回0否则

这个函数会把读到的数据存到第二个参数中,Read函数的第二个参数的意思是文件的类型,比如:text,ppt,jpg这种的,所以要用void*类型的任意类型

第三个参数则是拷贝数据的字节个数

Write

函数原型:int write(int fd,void *buf,size_t nbytes);

函数参数:

  • fd :要写入的文件的文件描述符
  • buf:  指向内存块的指针,从这个内存块中读取数据写入到文件中
  • nbytes: 要写入文件的字节个数

返回值

       如果出现错误,返回-1

       如果写入成功,则返回写入到文件中的字节个数

这边要注意,因为read和write的第二个参数都是一个指针类型的参数,所以在函数外部用同一个变量做接口,从read函数读取数据到一个变量里面,然后再用这个已经有数据的变量把这个数据通过write写入到对应的文件中

Close

  • 用close()系统调用释放打开的文件描述符

函数原型:int close(int fd);

函数参数:

  • fd :要关闭的文件的文件描述符

返回值

       如果出现错误,返回-1

       调用成功返回0

查看系统函数的头文件的方法

创建一个文件的注意点:

Linux有系统保护,外部通过open连接创建一个777的文件会被umask的权限掩码给阻拦

Umask指令返回022

Umask相当于是一个系统保护

因此我们要在open之前要关闭权限掩码,把umask设置为0

关于用只读模式打开文件,说明文件已经存在,因此不需要第三个参数

Read函数的第二个参数的意思是文件的类型,比如:text,ppt,jpg这种的,所以要用void*类型的任意类型

注意点

1.Linux中的变量必须要初始化,因此在VS2019中编写代码当我们定义一个变量时必须对其进行初始化,如下图

2.路径要加/根目录

这边打断点的原因是因为跨平台运行,代码在Windows,运行在linux,是GDB运行,必须要打断点运行

并且有cout就要加endl换行,必须要加,要不然程序不知道什么时候代码结束

代码

  • 26
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux上,使用DBus传递文件句柄需要以下步骤: 1. 定义DBus消息的格式,包含传递文件句柄的FD(File Descriptor)类型。 2. 在发送方进程中打开文件,并将文件句柄通过DBus消息发送给接收方进程。 3. 在接收方进程中接收DBus消息,并从消息中获取文件句柄。 4. 使用文件句柄进行文件操作,并在使用完成后关闭文件句柄。 以下是一个简单的C++代码示例,演示了如何使用DBus传递文件句柄: ```cpp #include <iostream> #include <dbus/dbus.h> #include <fcntl.h> #include <unistd.h> using namespace std; // 定义DBus消息的格式 static const char* DBUS_MSG_PATH = "/com/example/Test"; static const char* DBUS_MSG_INTERFACE = "com.example.TestInterface"; static const char* DBUS_MSG_NAME = "TestMessage"; static const char* DBUS_MSG_CONTENT = "This is a test message."; // 定义文件路径 static const char* FILE_PATH = "/tmp/test.txt"; int main() { // 初始化DBus连接 DBusError error; dbus_error_init(&error); DBusConnection* dbus_conn = dbus_bus_get(DBUS_BUS_SESSION, &error); if (dbus_error_is_set(&error)) { cerr << "DBus Connection Error: " << error.message << endl; dbus_error_free(&error); return 1; } // 创建DBus消息 DBusMessage* dbus_msg = dbus_message_new_signal(DBUS_MSG_PATH, DBUS_MSG_INTERFACE, DBUS_MSG_NAME); if (!dbus_msg) { cerr << "DBus Message Error: Failed to create dbus message." << endl; return 1; } // 打开文件并获取文件句柄 int fd = open(FILE_PATH, O_RDONLY); if (fd < 0) { cerr << "File Error: Failed to open file." << endl; return 1; } // 将文件句柄添加到DBus消息中 dbus_bool_t dbus_ret; dbus_ret = dbus_message_append_args(dbus_msg, DBUS_TYPE_UNIX_FD, &fd, DBUS_TYPE_INVALID); if (!dbus_ret) { cerr << "DBus Message Error: Failed to append file descriptor to dbus message." << endl; return 1; } // 发送DBus消息 dbus_ret = dbus_connection_send(dbus_conn, dbus_msg, NULL); if (!dbus_ret) { cerr << "DBus Connection Error: Failed to send dbus message." << endl; return 1; } // 等待DBus消息发送完成 dbus_connection_flush(dbus_conn); // 关闭文件句柄 close(fd); // 释放DBus消息和DBus连接 dbus_message_unref(dbus_msg); dbus_connection_unref(dbus_conn); return 0; } ``` 在接收方进程中,可以通过DBus回调函数接收DBus消息,并从消息中获取文件句柄。以下是一个简单的DBus回调函数示例: ```cpp #include <iostream> #include <dbus/dbus.h> #include <fcntl.h> #include <unistd.h> using namespace std; // 定义DBus消息的格式 static const char* DBUS_MSG_PATH = "/com/example/Test"; static const char* DBUS_MSG_INTERFACE = "com.example.TestInterface"; static const char* DBUS_MSG_NAME = "TestMessage"; static const char* DBUS_MSG_CONTENT = "This is a test message."; // 定义文件路径 static const char* FILE_PATH = "/tmp/test.txt"; // 定义DBus回调函数 DBusHandlerResult dbus_callback(DBusConnection* dbus_conn, DBusMessage* dbus_msg, void* user_data) { if (!dbus_msg) { return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; } // 获取DBus消息的类型和名称 const char* dbus_msg_type = dbus_message_type_to_string(dbus_message_get_type(dbus_msg)); const char* dbus_msg_name = dbus_message_get_member(dbus_msg); if (strcmp(dbus_msg_type, "signal") == 0 && strcmp(dbus_msg_name, DBUS_MSG_NAME) == 0) { // 从DBus消息中获取文件句柄 int fd; if (!dbus_message_get_args(dbus_msg, NULL, DBUS_TYPE_UNIX_FD, &fd, DBUS_TYPE_INVALID)) { cerr << "DBus Message Error: Failed to get arguments from dbus message." << endl; return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; } // 读取文件内容 char buffer[1024]; int nread = read(fd, buffer, sizeof(buffer)); if (nread < 0) { cerr << "File Error: Failed to read file." << endl; return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; } // 输出文件内容 cout << "File Content: " << buffer << endl; // 关闭文件句柄 close(fd); return DBUS_HANDLER_RESULT_HANDLED; } return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; } int main() { // 初始化DBus连接 DBusError error; dbus_error_init(&error); DBusConnection* dbus_conn = dbus_bus_get(DBUS_BUS_SESSION, &error); if (dbus_error_is_set(&error)) { cerr << "DBus Connection Error: " << error.message << endl; dbus_error_free(&error); return 1; } // 注册DBus回调函数 dbus_bus_add_match(dbus_conn, "type='signal',interface='" DBUS_MSG_INTERFACE "',member='" DBUS_MSG_NAME "'", &error); dbus_connection_add_filter(dbus_conn, dbus_callback, NULL, NULL); // 进入DBus消息循环 while (dbus_connection_read_write_dispatch(dbus_conn, -1)) {} // 释放DBus连接 dbus_connection_unref(dbus_conn); return 0; } ``` 需要注意的是,DBus传递文件句柄需要在DBus连接中启用FD_PASSING选项,并且DBus库的版本需要在1.9.8以上。在C语言中,可以使用dbus_connection_set_max_message_size()函数设置DBus消息的最大长度,以避免DBus消息过长导致传递文件句柄失败。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值