网络编程基础笔记 (Socket,同步,异步,NIO,BIO,AIO)

本文深入讲解网络编程基础知识,包括Socket通信原理,同步异步及阻塞非阻塞的区别,详细介绍BIO、NIO、AIO三种编程模型的特点与适用场景,帮助读者理解不同网络架构的选择依据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

网络编程基础

  • ajax: 异步阻塞
  • 异步是OS底层支持的一种特殊操作
  • 阻塞是一种方法的实现逻辑

1.Socket

  1. ip+port, 插座
  2. 三次握手四次挥手

2.同步异步

  1. 用户程序--内核 之间的交互而言
  2. 同步: 自己拿卡去取钱 异步: 指派小弟去拿钱回来

3.阻塞与非阻塞

  1. 是一种读取或者写入操作函数(方法)的实现方式
  2. 阻塞方式下读取或者写入函数将一直等待 非阻塞方式下不管结果如何会立即返回一个状态值
  3. 阻塞: 排队取款, 只能等待 非阻塞: 柜台取款, 取个号就去玩, 等到号通知再去

4.BIO 编程

  1. Blocking IO: 同步阻塞的编程方式
  2. 一个连接对应一个线程
  3. 适合于连接数目小, 且固定的架构,JDK1.4之前的唯一选择

5.NIO 编程

  1. Unblocking IO(New IO): 同步非阻塞的编程方式
  2. 基于事件驱动思想来完成的, 主要解决的是BIO的大并发问题
  3. 一个请求一个通道(SocketChannel), 一个线程轮询处理多个客户端---selector: 选择器(多路复用器), 用于注册通道
  4. 适用于连接数目多且连接比较短(轻操作)的架构, 比如聊天器, 并发局限于应用中, 编程复杂, jdk1.4之后开始支持

6.AIO 编程

  1. Asynchronous IO 异步非阻塞的编程方式
  2. 读写操作时, 只需直接调用API的read或write方法即可
  3. 服务器实现模式为一个有效请求一个线程, 客户端的I/O请求都是有OS先完成了再通知服务器应用去启动线程进行处理
  4. AIO方式适用于连接数目多且连接比较长(重操作)的架构,比如相册服务器, 充分调用OS参与并发操作, 编程比较复杂, jdk7 开始支持
资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领域,自动化构建与发布是提升开发效率项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建与发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排与可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push packageDeploy/Rollback。每个阶段都可以根据实际需求进行配置调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试部署,从而提高项目的整体质量可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值