1.接受tcp数据

#include <sys/socket.h>

ssize_t recv(int socket, void *buffer, size_t length, int flags);

socket:读取的socket文件描述符

buffer:缓冲区的位置

length:缓冲区的大小

flags:提供了额外的控制,有如下标志位:

  MSG_PEEK:窥探读缓存中数据,此次读操作不会导致这些数据被清除

  MSG_OOB:接收紧急数据(带外数据,out_of_band)

  MSG_WAITALL:在读取到指定数量的字节后才返回

2.发送tcp数据

#include <sys/socket.h>

ssize_t recv(int socket, const void *buffer, size_t length, int flags);

socket:写入的socket文件描述符

buffer:缓冲区的位置

length:缓冲区的大小

flags:提供了额外的控制,有如下标志位:

  MSG_OOB:接收紧急数据(带外数据,out_of_band)

  MSG_DONTROUTE:在送出分组时不使用网关.只有直接连接在网络上的主机 才能接收到数据.这个标志通常仅用于诊断和路由程序. 可路由的协议族才能使用这个标志;包套接字不可以.

  MSG_DONTWAIT:使用非阻塞式操作;如果操作需要阻塞,将返回 EAGAIN 错误(也可以用 F_SETFL fcntl(2) 设置 O_NONBLOCK 实现这个功能.)

  MSG_NOSIGNAL:当流式套接字的另一端中断连接时不发送 SIGPIPE 信号,但仍然返回 EPIPE 错误.

  MSG_CONFIRM (仅用于Linux 2.3以上版本):通知链路层发生了转发过程:得到了另一端的成功应答. 如果链路层没有收到通知,它将按照常规探测网络上的相邻 主机(比如通过免费arp). 只能用于 SOCK_DGRAM 和 SOCK_RAW类型的套接字,且仅对IPv4和IPv6有效。

 Demo 

send:

 

#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <assert.h>
#include <stdio.h>
#include <unistd.h>
#include <string.h>
#include <stdlib.h>

int main( int argc, char* argv[] )
{
    if( argc <= 2 )
    {
        printf( "usage: %s ip_address port_number\n", basename( argv[0] ) );
        return 1;
    }
    const char* ip = argv[1];
    int port = atoi( argv[2] );

    struct sockaddr_in server_address;
    bzero( &server_address, sizeof( server_address ) );
    server_address.sin_family = AF_INET;
    inet_pton( AF_INET, ip, &server_address.sin_addr );
    server_address.sin_port = htons( port );

    int sockfd = socket( PF_INET, SOCK_STREAM, 0 );
    assert( sockfd >= 0 );
    if ( connect( sockfd, ( struct sockaddr* )&server_address, sizeof( server_address ) ) < 0 )
    {
        printf( "connection failed\n" );
    }
    else
    {
        printf( "send oob data out\n" );
        const char* oob_data = "abc";
        const char* normal_data = "123";
        send( sockfd, normal_data, strlen( normal_data ), 0 );
        send( sockfd, oob_data, strlen( oob_data ), MSG_OOB );
        send( sockfd, normal_data, strlen( normal_data ), 0 );
    }

    close( sockfd );
    return 0;
}
View Code

相关文章:

  • 2021-11-16
  • 2021-09-17
  • 2021-10-03
  • 2022-12-23
  • 2021-05-20
  • 2021-06-29
  • 2021-10-03
  • 2022-01-12
猜你喜欢
  • 2021-12-02
  • 2021-09-09
  • 2022-12-23
  • 2021-07-26
  • 2021-12-04
  • 2022-01-23
  • 2022-02-14
相关资源
相似解决方案