socket编程 做一回文抄公

socket接口是TCP/IP网络的API,socket接口定义了许多函数或例程,程序员能够用他们来研发TCP/IP网络上的应用程式。要学Internet上的TCP/IP网络编程,必须理解socket接口。

socket接口设计者最先是将接口放在Unix操作系统里面的。假如了解Unix系统的输入和输出的话,就很容易了解Socket了。网络的socket数据传输是一种特别的I/O,socket也是一种文档描述符。socket也具备一个类似于打开文档的函数调用socket(),该函数返回一个整型的socket描述符,随后的连接建立、数据传输等操作都是通过该Socket实现的。常用的socket类型有两种:SOCK_STREAM和SOCK_DGRAM。STREAM是一种面向连接的socket,针对于面向连接的TCP服务应用;数据报式socket是一种无连接的socket,对应于无连接的UDP服务应用。

使用socket进行网络编程,首先需要创建一个socket,创建一个tcp类型的socket的代码如下:

int fd = socket(AF_INET, SOCK_STREAM, 0);

创建socket后,为了使用这个fd还需要为它绑定ip地址,代码如下:

sockaddr_inaddr;

addr.sin_family = AF_INET;

addr.sin_port = 0;

addr.sin_addr.S_un.S_addr = inet_addr("127.0.0.1");

int err = bind(fd, (sockaddr*)&addr, sizeof(socketaddr_in));

ipv4版本的socket编程中,网络地址用 sockaddr_in来表示:

 struct sockaddr_in{

     shorts in_family;

     /*Addressfamily一般来说AF_INET(地址族)PF_INET(协议族)*/

     unsigned shorts in_port;

     /*in_port必须采用网络数据格式,可以用htons()转换成网络数据格式*/

     struct in_addr sin_addr; /*ip 地址*/

     unsigned char sin_zero[8];

     /*没有实际意义,只是为了跟SOCKADDR结构在内存中对齐*/

 };

 struct in_addr{

     union{

         struct{unsigned char s_b1,s_b2,s_b3,s_b4;}S_un_b;

         struct{unsigned short s_w1,s_w2;}S_un_w;

         unsigned long S_addr;

     }S_un;

 };

使用bind函数将fd和地址绑定到一起:

 int bind(int fd, const struct sockaddr * address, socklen_t address_len);

在bind之后,就可以使用这个socket进行网络通信。

sockaddr_inaddraddr.sin_family = AF_INET;

addr.sin_port=htons(PORT);

addr.sin_addr.s_addr = inet_addr(SERVER_IP);

interr = connect(fd, (sockaddr*)&addr, sizeof(addr));

connect函数原型:

 int connect (int sockfd,struct sockaddr * serv_addr,int addrlen);

参数说明:

serv_addr:远端服务器地址

 addrlen:描述地址的结构体sockadd_in的长度

返回值:如果函数执行成功,返回值为0,否则为非0

远端服务器接收连接的代码如下:

int err = listen(fd, 5);

sockaddr_in addr;

int len = sizeof(addr);

err = accept(fd, (sockaddr*)&addr, &len);

listen函数原型:

 int listen(intsockfd,int backlog);

参数说明:

 sockfd:一个已绑定未被连接的套接字描述符

 backlog:连接请求队列(queue of pending connections)的最大长度(一般由2

TCP协议下发送数据的代码如下:

int len = send(fd, buf, len, 0);

send函数原型:

 int send(int sockfd, const void * buff, size_t nbytes, int flags);

参数说明:

 sockfd:指定发送端套接字描述符。

 buff:存放要发送数据的缓冲区

 nbytes:实际要改善的数据的字节数

 flags:一般设置为0

返回值:若无错误发生,send()返回所发送数据的总数(请注意这个数字可能小

TCP协议下接受数据的代码如下:

int len = recv(fd, buff, nbytes, 0);

recv函数原型:

 int recv(int sockfd, void * buff, size_t nbytes, int flags);

参数说明:

     sockfd:接收端套接字描述符

     buff:用来存放recv函数接收到的数据的缓冲区nbytes:指明buff的长度  

     flags:一般置为0

UDP协议下发送数据的代码如下:

int len = sendto(s,buffer,len,0,&addr,addr_len);

sendto函数原型:

int sendto(int fd, char * buf, int len, int flags,

            const struct sockaddr * to, int tolen);

参数说明:

 fd:套接字

 buf:待发送数据的缓冲区

 size:缓冲区长度

 flags:调用方式标志位, 一般为0, 改变flags,将会改变sendto发送的形式

 addr:目的地址

 len:描述地址的结构体sockadd_in的长度

UDP协议下接受数据的代码如下:

int len = recvfrom(fd,buf,buflen,0,(sockaddr*)&addr,&len);

recvfrom函数原型:

 int recvfrom(int fd, void * buf,int len, unsigned int flags,

              struct sockaddr * from, socket_t * fromlen);

参数说明:

     fd:标识一个已连接套接口的描述字。

     buf:接收数据缓冲区。

     len:缓冲区长度。

     flags:调用操作方式。

from:(可选)指针,指向保存发送地址的缓冲区。用于返回发送地址

     fromlen:(可选)指针,指向from缓冲区长度值。


self.processlagerbuf

时间: 2024-10-25 00:44:32

socket编程 做一回文抄公的相关文章

socket编程之并发回射服务器3

在socket编程之并发回射服务器一文中,服务器采用多进程的方式实现并发,本文采用多线程的方式实现并发. 多线程相关API: // Compile and link with -pthread int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void *(*start_routine) (void *), void *arg); int pthread_join(pthread_t thread, void **

[编程题-蘑菇街]回文串

[编程题] 回文串 给定一个字符串,问是否能通过添加一个字母将其变为回文串. 输入描述: 一行一个由小写字母构成的字符串,字符串长度小于等于10. 输出描述: 输出答案(YES\NO). 输入例子: coco 输出例子: YES #include<iostream> #include<string> using namespace std; bool f(string& s, int i) { int l = 0, r = s.size() - 1; if (l == i)

微软编程之美——回文字符序列

描述 给定字符串,求它的回文子序列个数.回文子序列反转字符顺序后仍然与原序列相同.例如字符串aba中,回文子序列为"a", "a", "aa", "b", "aba",共5个.内容相同位置不同的子序列算不同的子序列. 限制 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 输入 第一行一个整数T,表示数据组数.之后是T组数据,每组数据为一行字符串. 输出 对于每组数据输出一行,格式为&q

牛客网在线编程:统计回文数

题目描述: "回文串"是一个正读和反读都一样的字符串,比如"level"或者"noon"等等就是回文串.花花非常喜欢这种拥有对称美的回文串,生日的时候她得到两个礼物分别是字符串A和字符串B.现在她非常好奇有没有办法将字符串B插入字符串A使产生的字符串是一个回文串.你接受花花的请求,帮助她寻找有多少种插入办法可以使新串是一个回文串.如果字符串B插入的位置不同就考虑为不一样的办法.例如:A = "aba",B = "b&

编程小练习--回文数链长

题: 一个数加上他颠倒过来的数,直到最终结果是个回文数,看需要几步. 例如:87 + 78 = 165; 165 + 561 = 726; 726 + 627 = 1353; 1353 + 3531 = 4884  结果为 4. 答: var palindromeChainLength = function(n) { var m = reverseNum (n); if(m===n) { return 0; } else { return 1 + palindromeChainLength(m+

hdu_1282 回文数猜想

(最近水题刷的比较多,不过还是有些收获,所以还是做个记录比较好) http://acm.hdu.edu.cn/showproblem.php?pid=1282 分析: 题目理解起来还是简单的,基本上有两种思路:1) 将int转为string来实现: 2)直接用int做(回文串判断,相加) 第二中思路比较直接,将一个数倒置得到新的数,然后判断是否是回文数(两个数值相等):不过鄙人采用了第一种方法,因为字符串的操作不太熟练,需要联系来着. 字符串操作: string -->  int int a;

Python 基础之socket编程(二)

Python 基础之socket编程(二) 昨天只是对socket编程做了简单的介绍,只是把socket通信的框架搭建起来,要对其中的功能进行进一步的扩充,就来看看今天的料哈! 一.基于tcp的套接字 1. tcp的服务端 ss = socket() #创建服务器套接字 ss.bind() #把地址绑定到套接字 ss.listen() #监听链接 inf_loop: #服务器无限循环 cs = ss.accept() #接受客户端链接 comm_loop: #通讯循环 cs.recv()/cs.

【LeetCode每天一题】 Valid Palindrome(有效的回文)

Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignoring cases. Note: For the purpose of this problem, we define empty string as valid palindrome. Example 1: Input: "A man, a plan, a canal: Panama" O

48.输入任意正整数,编程判断该数是否为回文数(回文数是指从左到右读与从右到左读一样,如12321)

//1.输入一个数,将其每一位分离,并保存如一个数组 //2.判断数组最后录入的一位是第几位 //3.循环判断是否满足回问数的要求 #include<iostream> using namespace std; int main() { int n,temp; int k=0; int a[20]; cout<<"please input an number: "<<endl; cin>>n; for(int i=0;i<20;i+