博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
伪终端之打开伪终端设备
阅读量:6453 次
发布时间:2019-06-23

本文共 970 字,大约阅读时间需要 3 分钟。

各种平台打开伪终端设备的方法有所不同。在Single UNIX Specification的XSI扩展中包含了很多函数,试图统一这些方法。这些函数的基础是SVR4用于管理基于STREAMS的伪终端的一组函数。

 

posix_openpt用来打开下一个可用的伪终端主设备,该函数是可移植的。

#include <stdlib.h>

#include <fcntl.h>

int posix_openpt(int oflag);

返回值:若成功则返回下一个可用的PTY主设备的文件描述符,若出错则返回-1

参数oflag是一个位屏蔽字,指定如何打开主设备,它类似于open(2)的oflag参数,但是并不支持所有打开标志。对于posix_openpt,我们可以指定O_RDWR, 要求打开主设备进行读、写;可以指定O_NOCTTY以防止主设备成为调用者的控制终端。其他打开标志都会导致未定义的行为。

 

grantpt函数提供的功能:在伪终端从设备可被使用之前,必须设置它的权限,使得应用程序可以访问它。它把从设备节点的用户ID设置为调用者的实际用户ID, 设置其组ID为一非指定值,通常是可以访问该终端设备的组。将权限设置为:对单个所有者是读写,对组所有者是写(0620)。

#include <stdlib.h>

int grantpt(int filedes);

int unlockpt(int filedes);

两个函数的返回值: 若成功则返回0,若出错则返回-1

unlockpt函数用于准予对伪终端从设备的访问,从而允许应用程序打开该设备。阻止其他进程打开从设备,使得建立该设备的应用程序有机会在使用主、从设备之前正确地初始化这些设备。

注意,在grantpt和unlockpt这两个函数中,文件描述符是与主伪终端设备关联的文件描述符。

 

ptsname函数用于在给定主伪终端设备的文件描述符时,找到从伪终端设备的路径名。这使应用程序可以独立于给定平台的某种惯例而标识从设备。注意,该函数返回的名字可能存放在静态存储区中,所以以后的调用可能会覆盖它。

#include <stdlib.h>

char *ptsname(int filedes);

返回值:若成功则返回指向PTY从设备名的指针,若出错则返回NULL

 

详情可参考apue。

转载地址:http://vpfzo.baihongyu.com/

你可能感兴趣的文章
IE9下不显示select
查看>>
day24-组合搜索组件
查看>>
Swagger-UI报Unable to infer base url
查看>>
gcc/g++ 实战之编译的四个过程
查看>>
InnoDB杂记
查看>>
【PHP基础】PHP与Web页面交互(表单处理)
查看>>
能用条件注释改善的IE兼容问题
查看>>
UVA 10692 Huge Mods(指数循环节)
查看>>
awardactivity/classfragment
查看>>
WPF and Silverlight 学习笔记(二十五):使用CollectionView实现对绑定数据的排序、筛选、分组...
查看>>
Linux Shell多命令执行
查看>>
【递推】月落乌啼算钱
查看>>
RCC BUCK变压器设计
查看>>
DAO层,Service层,Controller层、View层
查看>>
LeetCode刷题系列——Add Two Numbers
查看>>
python3.4.3 调用http接口 解析response xml后插入数据库
查看>>
使用VS2008,VS2010编译64位的应用程序
查看>>
关于java Integer大小比较的问题
查看>>
C++创建学生类练习
查看>>
C# 如何生成CHM帮助文件
查看>>