之前一直以为time_wait状态就是主动关闭的那一方产生.然后这个端口一直不可以用.实际我发现服务端监听一个端口.客户端发来连接后.传输数据后.服务端关闭客户端套接字后.用netstat -nat | grep 端口 查看了产生了time_wait.但客户端依然可以不断连接服务端.然后服务端不断关闭.并不会影响监听端口.原来是只有服务端把监听端口描述符给关闭(不是accept那个连接.虽然,端口相同),在2mls时间内再次启动这个端口..就会提示Address already in use

另外inet_pton(AF_INET,ip地址,&serv_addr.sin_addr);
  1. #include "unp.h"
  2. int main(int argc,char *argv[])
  3. { if(argc<2)
  4. {
  5. printf("please input server_ip\n");
  6. return 0;
  7. }
  8. int fd=socket(AF_INET,SOCK_STREAM,0);
  9. if(fd<0)
  10. err_quit("socket create error");
  11. struct sockaddr_in servaddr;
  12. struct sockaddr_in clientaddr;
  13. clientaddr.sin_family=AF_INET;
  14. clientaddr.sin_port=htonl(5900);
  15. clientaddr.sin_addr.s_addr=htons(INADDR_ANY);
  16. bind(fd,(SA*)&clientaddr,sizeof(clientaddr));`
  17. servaddr.sin_family=AF_INET;//message proctoal
  18. servaddr.sin_port=htons(13);
  19. if(inet_pton(AF_INET,argv[1],&servaddr.sin_addr)<0)
  20. err_quit("inet_pton error");
  21. if(connect(fd,(SA*)&servaddr,sizeof(servaddr))<0)
  22. err_quit("connect error");
  23. char buf[1024];
  24. int read_length=0;
  25. int count=0;
  26. while((read_length=read(fd,buf,sizeof(buf)))>0)
  27. { count++;
  28. buf[read_length]='\0';
  29. printf("%s\n read %d ",buf,count);
  30. }
  31. printf("count=%d\n",count);
  32. if(read_length<0)
  33.      err-quit("error of read");
  34.      close(fd);
  35.      return 0;

服务端
  1. #include "unp.h"
  2. #include <time.h>
  3. int main(int argc,char *argv[])
  4. {
  5. int listenfd=Socket(AF_INET,SOCK_STREAM,0);
  6. struct sockaddr_in servaddr;
  7. servaddr.sin_family=AF_INET;
  8. inet_pton(AF_INET,"0.0.0.0",&servaddr.sin_addr);
  9. servaddr.sin_port=htons(13);
  10. Bind(listenfd,(SA*)&servaddr,sizeof(servaddr));
  11. Listen(listenfd,10);
  12. time_t ticks;
  13. int i;
  14. char buf[1024];
  15. for(;;)
  16. {
  17. int client_fd=accept(listenfd,NULL,0);
  18. ticks=time(NULL);
  19. snprintf(buf,sizeof(buf),"%.24s\r\n",ctime(&ticks));
  20. for(i=0;i<strlen(buf);++i)
  21. Write(client_fd,&buf[i],1);
  22. Close(client_fd);
  23. //Close(listenfd);
  24. }
  25. return 0;
  26. }
  27. ~
1.5题 不同tcp对数据做不同的处理,每次读取会发现count不同.

unix网络编程第一章demo的更多相关文章

  1. c#网络编程-第一章

    1.需求 获得网页数据,并填充到webbrowser空间中 2.代码示例 private void button1_Click_1(object sender, EventArgs e) { //1. ...

  2. UNIX网络编程 第6章 I/O复用:select和poll函数

    UNIX网络编程 第6章 I/O复用:select和poll函数

  3. UNIX网络编程 第5章 TCP客户/服务器程序示例

    UNIX网络编程 第5章 TCP客户/服务器程序示例

  4. unix 网络编程 第五章

    个人对unix 网络编程中的代码进行了精简,保留了主要和关键部分. 1 tcpserve01 程序见 https://github.com/juniperdiego/Unix-network-prog ...

  5. 《UNIX网络编程》TCP客户端服务器例子

    最近在看<UNIX网络编程>(简称unp)和<Linux程序设计>,对于unp中第一个获取服务器时间的例子,实践起来总是有点头痛的,因为作者将声明全部包含在了unp.h里,导致 ...

  6. 【unix网络编程第三版】阅读笔记(五):I/O复用:select和poll函数

    本博文主要针对UNP一书中的第六章内容来聊聊I/O复用技术以及其在网络编程中的实现 1. I/O复用技术 I/O多路复用是指内核一旦发现进程指定的一个或者多个I/O条件准备就绪,它就通知该进程.I/O ...

  7. 【unix网络编程第三版】阅读笔记(三):基本套接字编程

    unp第三章主要介绍了基本套接字编程函数.主要有:socket(),bind(),connect(),accept(),listen()等. 本博文也直接进入正题,对这几个函数进行剖析和讲解. 1. ...

  8. 《Unix 网络编程》11:名字和地址转换

    名字和地址转换 系列文章导航:<Unix 网络编程>笔记 域名系统 简介 域名系统主要用于主机名字和 IP 地址之间的映射.主机名可以是: 简单名字,如:centos01 全限定域名(FQ ...

  9. 【Linux/unix网络编程】之使用socket进行TCP编程

    实验一 TCP数据发送与接收 [实验目的] 1.熟练掌握套接字函数的使用方法. 2.应用套接字函数完成基本TCP通讯,实现服务器与客户端的信息交互. [实验学时] 4学时 [实验内容] 实现一个服务器 ...

随机推荐

  1. HTTP无状态协议和session原理(access_token原理)

    无状态协议是指协议对务处理没有记忆能力.缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大.另一方面,在服务器不需要先前信息时它的应答就较快. Http协议不 ...

  2. 洛谷 P1593 因子和

    https://www.luogu.org/problemnew/show/P1593#sub 利用约数和定理:可以去看一下公式第13条 然后这个题目的话,要求$a^b$,那么我们首先可以先将a分解然 ...

  3. C++函数的默认参数补充

    1.函数定义时指定默认参数 在C++中,定义函数时可以给形参指定一个默认的值,这样调用函数时如果没有给这个形参赋值(没有对应的实参),那么就使用这个默认的值.也就是说,调用函数时可以省略有默认值的参数 ...

  4. PHP将html内容转换为image图片

    /** * 将html内容转换为image图片 * @param $htmlcontent * @param $toimagepath * @author james.ou 2011-11-1 */ ...

  5. C语言结构体初始化的四种方法(转载)

    原文:https://blog.csdn.net/ericbar/article/details/79567108 定义 struct InitMember { int first: double s ...

  6. 监控网络流量iftop和nethogs安装

    服务器环境是centos7,centos下通常使用iftop,或者nethogs来进行网络流量监控.这2个工具都需要先安装epel,因为这个库通常操作系统是不自带的.那么就先安装epel,使用的命令是 ...

  7. Hadoop4.2HDFS测试报告之五

    第二组:文件存储读过程记录 NameNode:1 DataNode:1 本地存储 scp romotepath localpath 500 2 1 23.05 NameNode:1 DataNode: ...

  8. 使用像AdminLTE的前端框架,树形导航菜单实现方式都有哪些?

    之前用easyui等富前端框架开发的时候都是使用封装好的县城的插件,现在使用最新的类似AdminLTE似的前段框架实现树形菜单都用什么方式? 后台拼接html然后前端用JS append方法添加还是直 ...

  9. 大数据学习——sparkSql对接hive

    1.   安装mysql 2.   上传.解压.重命名 2.1.  上传 在随便一台有hadoop环境的机器上上传安装文件 su - hadoop rz –y 2.2.  解压 解压缩:apache- ...

  10. linux 基础 软件的安装 *****

    一软件的安装   原代码与tarball 源代码---->编译------>可执行文件 查看文件类型   file命令    是否是二进制文件 注意如果文件的可执行权限 .c结尾的源文件- ...