Linux网络编程--文件属性fcntl函数

2024-05-08 21:48

本文主要是介绍Linux网络编程--文件属性fcntl函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这里写图片描述

/*使用fcntl控制文件符*/
#include <unistd.h>
#include <fcntl.h>
#include <stdio.h>int main(void)
{int flags = -1;int accmode = -1;/*获得标准输入的状态的状态*/flags = fcntl(0, F_GETFL, 0);if( flags < 0 ){/*错误发生*/printf("failure to use fcntl\n");return -1;}/*获得访问模式*/accmode = flags & O_ACCMODE;  if(accmode == O_RDONLY)/*只读*/printf("STDIN READ ONLY\n");else if(accmode == O_WRONLY)/*只写*/printf("STDIN WRITE ONLY\n");else if(accmode ==O_RDWR)/*可读写*/printf("STDIN READ WRITE\n");else/*其他模式*/printf("STDIN UNKNOWN MODE");if( flags & O_APPEND )printf("STDIN APPEND\n");if( flags & O_NONBLOCK )printf("STDIN NONBLOCK\n");return 0;
}

这里写图片描述

例子一:使用函数int fcntl(int fd,int cmd);返回值为新的文件描述符/*使用fcntl修改文件的状态值*/
#include <unistd.h>
#include <fcntl.h>
#include <stdio.h>
#include <string.h>/*strlen函数*/#define NEWFD 8
int main(void)
{char buf[] = "FCNTL";int fd = open("test.txt", O_RDWR);printf("the file test.txt ID is %d\n",fd);/*获得文件状态*/  fd = fcntl(fd, F_GETFD);printf("the file test.txt ID is %d\n",fd);fd = NEWFD;/*将状态写入*/fcntl(NEWFD, F_SETFL, &fd);/*向文件中写入字符串*/write(NEWFD, buf, strlen(buf));close(NEWFD);return 0;
}例子二:使用函数int fcntl(int fd,int cmd,long arg);返回值为获得的响应标志位
/*使用fcntl修改文件的状态值*/
#include <unistd.h>
#include <fcntl.h>
#include <stdio.h>
#include <string.h>/*strlen函数*/int main(void)
{int flags = -1;char buf[] = "FCNTL";int fd = open("test.txt", O_RDWR);/*获得文件状态*/  flags = fcntl(fd, F_GETFL, 0);/*增加状态为可追加*/flags |= O_APPEND;/*将状态写入*/flags = fcntl(fd, F_SETFL, &flags);if( flags < 0 ){/*错误发生*/printf("failure to use fcntl\n");return -1;}/*向文件中写入字符串*/write(fd, buf, strlen(buf));close(fd);return 0;
}

/*使用fcntl获得接收信号的进程ID*/
#include <unistd.h>
#include <fcntl.h>
#include <stdio.h>#define NEWFD 8
int main(void)
{int uid;    /*打开文件test.txt*/int fd = open("test.txt", O_RDWR);/*获得接收信号的进程ID*/ uid = fcntl(fd, F_GETOWN);printf("the SIG recv ID is %d\n",uid);close(fd);return 0;
}

这里写图片描述

/*使用fcntl设置接收信号的进程ID:1000*/
#include <unistd.h>
#include <fcntl.h>
#include <stdio.h>#define NEWFD 8
int main(void)
{int uid;    /*打开文件test.txt*/int fd = open("test.txt", O_RDWR);  /*获得接收信号的进程ID*/ uid = fcntl(fd, F_SETOWN,1000); close(fd);  return 0;
}

这篇关于Linux网络编程--文件属性fcntl函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了

poj 2112 网络流+二分

题意: k台挤奶机,c头牛,每台挤奶机可以挤m头牛。 现在给出每只牛到挤奶机的距离矩阵,求最小化牛的最大路程。 解析: 最大值最小化,最小值最大化,用二分来做。 先求出两点之间的最短距离。 然后二分匹配牛到挤奶机的最大路程,匹配中的判断是在这个最大路程下,是否牛的数量达到c只。 如何求牛的数量呢,用网络流来做。 从源点到牛引一条容量为1的边,然后挤奶机到汇点引一条容量为m的边