zl程序教程

您现在的位置是:首页 >  Java

当前栏目

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

2023-04-18 14:29:35 时间

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

网络编程的本质


通信的基础

数据源是多样的,例如文件,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提供的线程池