分配伪终端,以及使得这个伪终端可以实际使用
int getpt (void)
:
返回下一个可用的伪终端master端的文件描述符.
int grantpt(int filedes)
:
改变文件描述符对应的伪终端master端设备对应的slave设备的所有权和访问权限.所有者设
置为调用进程的实际用户ID,组设置为一个特殊的组(通常是tty)或者是调用进程的实际组
ID. 访问权限通常是所有者可读可写,而组内只写.
int unlockpt (int filedes)
:
解除文件描述符对应的伪终端主设备对应的从设备. 在许多系统中从设备都只有在解锁后才
能访问,所以在试图打开从设备的时候通常总是先调用unlockpt
char *ptsname (int filedes)
:
如果文件描述符对应伪终端主设备,返回对应的从设备文件名,静态分配内存
在shell中cat < 另一个终端中tty的结果
,在那个终端中的输入会丢失,终端echo回来的没
有输入那么多,而cat这里则有其丢失的输出,cat这里打开的是一个从设备,那个终端对应的
终端模拟器程序应该是对应主设备, 获取用户输入给从设备,将来自从设备的输入写到屏幕.
说回来,平时运行在终端中运行的程序的标准输入输出应该就是从设备吧,
那么大致是这么个流程吧?对输入的竞争在多个从端都在读的时候会出现,shell大多数时候
都在读状态,等待输入,因此输入竞争很容易出现,但是输出的时候就是少数了哈,不太容易出
现竞争,怎么验证一下呢… 我在想什么呢,输入只能读一次,输出也只能输出一次,但是输出
本来就只要输出一次啊妈的,
窗口<-->终端模拟器进程<-->pty master端 <--> n * pty slave端