RTSPSERVER 遇到的函数

2023-12-10 22:20
文章标签 函数 遇到 rtspserver

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

ioctlsocket

◆I/O操作函数:主要用于获取与套接字相关的操作参数。

int ioctlsocket(SOCKET s, long cmd, u_long FAR * argp );

s为I/O操作的套接字。

cmd为对套接字的操作命令。

argp为命令所带参数的指针。

常见的命令: //确定套接字自动读入的数据量

FIONBIO:允许或禁止套接口s的非阻塞模式。argp指向一个无符号长整型。如 允许非阻塞模式则非零,如禁止非阻塞模式则为零。当创建一个套接口时,它就 处于阻塞模式(也就是说非阻塞模式被禁止)。这与BSD套接口是一致的。WSAAs ynSelect()函数将套接口自动设置为非阻塞模式。如果已对一个套接口进行了WS AAsynSelect() 操作,则任何用ioctlsocket()来把套接口重新设置成阻塞模式的 试图将以WSAEINVAL失败。为了把套接口重新设置成阻塞模式,应用程序必须首先 用WSAAsynSelect()调用(IEvent参数置为0)来禁至WSAAsynSelect()。

FIONREAD:确定套接口s自动读入的数据量。argp指向一个无符号长整型,其中 存有ioctlsocket()的返回值。如果s是SOCKET_STREAM类型,则FIONREAD返回在一 次recv()中所接收的所有数据量。这通常与套接口中排队的数据总量相同。如果 S是SOCK_DGRAM 型,则FIONREAD返回套接口上排队的第一个数据报大小。

SIOCATMARK:确实是否所有的带外数据都已被读入。这个命令仅适用于SOCK_S TREAM类型的套接口,且该套接口已被设置为可以在线接收带外数据(SO_OOBINL INE)。如无带外数据等待读入,则该操作返回TRUE真。否则的话返回FALSE假, 下一个recv()或recvfrom()操作将检索“标记”前一些或所有数据。应用程序可 用SIOCATMARK操作来确定是否有数据剩下。如果在“紧急”(带外)数据前有常 规数据,则按序接收这些数据(请注意,recv()和recvfrom()操作不会在一次调 用中混淆常规数据与带外数据)。argp指向一个BOOL型数,ioctlsocket()在其中 存入返回值。

setsockopt

在Linux中,TCP连接的套接字选项通常位于SOL_SOCKET和IPPROTO_TCP层。常用的TCP连接选项包括:

  • SO_KEEPALIVE:用于维护TCP连接的选项。启用此选项后,如果在一段时间内没有数据传输,则操作系统会自动发送一个探测报文,以检测连接是否已断开。
  • TCP_NODELAY:用于禁用Nagle算法的选项。启用此选项后,TCP数据包将立即发送,而不是等待缓冲区填满。
  • SO_REUSEADDR: 允许多个套接字在同一端口上绑定。该选项常用于服务器程序中,以处理多个客户端连接。
  • TCP_QUICKACK:用于快速确认接收到的数据包的选项。启用此选项后,操作系统会立即发送一个确认报文,而不是等待一段时间后再发送。
  • TCP_KEEPIDLE:用于设置探测报文的发送间隔时间的选项。
  • TCP_KEEPINTVL:用于设置探测报文发送的间隔时间的选项。
  • TCP_KEEPCNT:用于设置在没有响应的情况下重新发送探测报文的次数的选项。
  • TCP_SYNCNT:用于设置在建立连接期间尝试发送SYN报文的次数的选项。
  • TCP_MAXSEG:用于设置TCP数据包的最大大小的选项。
  • TCP_WINDOW_CLAMP:用于限制TCP窗口大小的选项。

chrono库

chrono介绍_<chrono>-CSDN博客

这篇关于RTSPSERVER 遇到的函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

解决JavaWeb-file.isDirectory()遇到的坑问题

《解决JavaWeb-file.isDirectory()遇到的坑问题》JavaWeb开发中,使用`file.isDirectory()`判断路径是否为文件夹时,需要特别注意:该方法只能判断已存在的文... 目录Jahttp://www.chinasem.cnvaWeb-file.isDirectory()遇

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

Java function函数式接口的使用方法与实例

《Javafunction函数式接口的使用方法与实例》:本文主要介绍Javafunction函数式接口的使用方法与实例,函数式接口如一支未完成的诗篇,用Lambda表达式作韵脚,将代码的机械美感... 目录引言-当代码遇见诗性一、函数式接口的生物学解构1.1 函数式接口的基因密码1.2 六大核心接口的形态学

Oracle的to_date()函数详解

《Oracle的to_date()函数详解》Oracle的to_date()函数用于日期格式转换,需要注意Oracle中不区分大小写的MM和mm格式代码,应使用mi代替分钟,此外,Oracle还支持毫... 目录oracle的to_date()函数一.在使用Oracle的to_date函数来做日期转换二.日

mysql主从及遇到的问题解决

《mysql主从及遇到的问题解决》本文详细介绍了如何使用Docker配置MySQL主从复制,首先创建了两个文件夹并分别配置了`my.cnf`文件,通过执行脚本启动容器并配置好主从关系,文中还提到了一些... 目录mysql主从及遇到问题解决遇到的问题说明总结mysql主从及遇到问题解决1.基于mysql

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

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>