博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UNIX网络编程卷1:套接字联网API-第一部分:简介
阅读量:4213 次
发布时间:2019-05-26

本文共 1295 字,大约阅读时间需要 4 分钟。

  在学习网络编程的时候,特别是对偏C系的同学来说,网络编程卷1/卷2和高级环境编程都是必修课。本系列博客从简介开始,对课本重要部分,结合自己的理解一一解读,并对自己在学习的过程中碰到的问题进行一一记录。 

1.在学习软件编程的时候,我们第一步是先学会一门语言,然后实现一个小模块(封装成类,函数等),来完成某个具体功能或解决某个具体问题。然后在参与真正项目的时候,往往涉及到大量的封装,模块与模块之间的如何设计,如何使得可扩展性更好等又涉及到设计模式的问题。但模块与模块之间并不一定只在一个进程中,更不一定在一台机器之上,那么当我们需要进程与进程之间进行交流,不同网络节点之间需要交流之时,应该如何处理呢。进程与进程的通信(IPC inter-process communication),推荐UNIX进程间通信(卷二),我们首先来讨论网络节点之间的通信(UNIX网络编程卷1)。这几本书主要向我们描述了UNIX是如何处理上述问题的,以及常用系统调用,讲述了部分原理,虽然其中有很多接口在实际编程中被封装或者是被取代,但依旧具有很强的借鉴意义。

 理解网络通信程序的步骤:

        1.确定不同网络节点之间程序通信所用到的协议。

                什么是通信协议?这是个很大的概念。计算机四大基础课之一--《计算机网络》本应该是对这个问题的详尽描述。但本科书籍中还是讲解太浅,以抽象讲述为主,并没有详尽展开(以后慢慢讲解)。简单来说,(参见百科)通信协议是指双方实体完成通信或服务所必须遵循的规则和约定。通过通信信道和设备互连起来的多个不同地理位置的系统,要使其能协同工作实现信息交换和资源共享,它们之间必须具有共同的语言。交流什么、怎样交流及何时交流,都必须遵循某种互相都能接受的规则。这个规则就是通信协议。

             对于刚入门的朋友来讲,就算看完了刚才的讲解,还是只能有个大致概念,我举个不恰当但能被容易理解的例子:

通过网络传输,通信双方都可以认为是基于二进制数据操作的。也就是说,发送方发送了一连串的二进制数据,通过网络,接收方接收到了这串二进制数据(例如 10001001),然后这个8位二进制中的每一位或者每几位代表了某种意思,具体代表哪些意思,怎么解析,我们事先就可以指定发送方和接收方都遵循这个规则。(当然,通信协议还规定了很多其他的东西,如通信时间 排序规则等等,此处不一一举出)

        2.确定网络模型

   client-server模型是最常见的模型(但网络通信中还有其他模型,以后碰到再详解)。需要明确的是,服务器进程一般都要写为守护进程(暂且理解成要在服务器上长时间运行,不主动关闭),在这里我想到了一个插曲:玩c/c++的新手童鞋们经常会碰到一个问题,他们经常会忘记释放申请的内存导致内存泄露,然而他们还是一脸无所谓,因为很多书籍中有这么一句话,在这个程序整体运行结束后,操作系统会自动回收所有相关资源(包括内存),于是他们每次很淡定,不是很在意手动释放内存。大哥。。你这个程序是运行一次完了就关闭了,然而若是写服务器端程序(并不会主动关闭),这个内存泄露的口子只会越来越大,最终结果你懂的~~

转载地址:http://ijumi.baihongyu.com/

你可能感兴趣的文章
Tomcat NioEndPoint初探
查看>>
Tomcat NIO/APR对静态资源提速
查看>>
Servlet Filter与Spring interceptor的执行顺序
查看>>
使用HttpServletResponseWrapper获取渲染jsp以后的html
查看>>
Tomcat的ThreadLocalLeakPreventionListener工作原理
查看>>
利用springMVC的interceptor实现页面性能监控(Filter亦可)
查看>>
SpringMVC 拦截器实现分析
查看>>
初始化(Map,List)容器类的容量会有一定的性能提升
查看>>
StringBuffer与StringBuilder浅析
查看>>
BoneCP数据源记录SQl比hibernate的show sql好用
查看>>
对Cookie的一点认识
查看>>
说一说hibernate的Get和Load
查看>>
如何修改tomcat的server信息增加服务器的安全
查看>>
浅谈tomcat的ThreadLocalLeakPreventionListener实现原理
查看>>
说一下多线程中用到的join
查看>>
扩展hibernate Criteria的Order使其支持sql片段(oracle)
查看>>
spring+mybatis利用interceptor(plugin)实现数据库读写分离
查看>>
NIO[SelectableChannel.register和Selector.select会有锁等待冲突]
查看>>
httpclient3.1的relaseConnection的misunderstand
查看>>
ReentrantLock为啥会出现不公平的场景
查看>>