java网络编程系列之java.io专业术语

x33g5p2x  于2021-11-30 转载在 Java  
字(0.9k)|赞(0)|评价(0)|浏览(401)

网络编程的本质

通信的基础

数据源是多样的,例如文件,java可序列化对象,字符串等…

java.io大家族

java.io里面的字符流

更复杂的子类:

上面这些类是在基础的四个字符流对象之上,使用装饰器模式,对其做了功能的增强,因此在使用这些类的时候,还需要传入一个被增强的对象

例如:

  • BufferedReader增加一个缓冲区
  • FilterReader提供了对字符的过滤功能
  • InputStreamReader作为字节流和字符流转换的桥接对象

java.io里面的字节流

  • BufferedInputStream: 提供一个缓冲区
  • DataOutputStream: 对于java基本数据类型的快速读取与写出

java.io里面的装饰器模式

Socket概述

socket又被叫做套接字

1.应用进程创建socket

2.根据ip+端口确定唯一个应用进程,并将这个信息告诉网卡驱动程序

3.应用进程将需要发送的数据发送给socket

4.网卡收到socket发送的数据

1.应用进程创建socket

2.根据ip+端口确定唯一个应用进程,并将这个信息告诉网卡驱动程序

3.网卡将数据发送给对应socket

4.应用进程从socket中读取到数据

同步异步阻塞非阻塞

举个栗子:

同步: 男生向心仪的女神表白,女神原地思考了很久才给出答案,对于接受方来说是同步行为

异步: 男生向心仪的女神表白,女神并没有立马给出答案,而是让男孩等消息,女神可能有别的事情要处理,或者可以理解为女神一边考虑要不要接受表白,一边又忙着处理其他事情,对于接受方来说是异步行为

阻塞: 男生向心仪的女神表白,不论女神是同步还是异步,男生一直都等待着女神的回复,别的啥事情都不干,对于请求方来说是阻塞行为

非阻塞: 男生向心仪的女神表白,不论女神是同步还是异步,男生一边想着表白的事情,一边又想着手头的bug和需求还没改完,对于请求方来说是非阻塞行为

网络通信中的线程池

显然,如果只有一个进程处理请求,那么会很耗时间,解决办法,就是多开几个进程同时处理请求

创建新线程和回收旧线程都非常耗费资源,那么怎么处理呢? —>复用现有的线程

我们会把这样一组被复用的线程成为线程池

java提供的线程池

相关文章