最新《廖雪峰java项目实战》

本文介绍了一种基于定界符的成帧技术实现方法。通过定义特定的定界符(如换行符),该技术可以确保消息在传输过程中被正确地分割和重组。文章详细描述了如何检查消息中是否包含定界符,以及如何使用定界符进行消息的发送与接收。

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

一、定界符成帧
Framer接口

package framer;

import java.io.IOException;
import java.io.OutputStream;

public interface Framer {
    /**
     * 添加成帧信息并将指定消息输出到指定流
     * @param message
     * @param out
     * @throws IOException
     */
    void frameMsg(byte[] message, OutputStream out) throws IOException;

    /**
     * 扫描指定的流,从中抽取下一条信息
     * @return
     * @throws IOException
     */
    byte[] nextMsg() throws IOException;
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
基于定界符的成帧

package framer;

import java.io.*;

/**
 * @ClassName DelimFramer
 * @Description TODO
 * @Author Cays
 * @Date 2019/3/16 22:04
 * @Version 1.0
 **/
public class DelimFramer implements Framer {
    //输入流
    private InputStream in;
    //定界符为换行符
    private static final byte DELIMITER='\n';

    public DelimFramer(InputStream in) {
        this.in = in;
    }

    @Override
    public void frameMsg(byte[] message, OutputStream out) throws IOException {
        //检测信息中是否包含换行符
        for (byte b:message){
            if (b==DELIMITER){
                throw new IOException("Message contaions delimiter");
            }
        }
        //将成帧的信息输出到流中
        out.write(message);
        //添加定界符
        out.write(DELIMITER);
        out.flush();
    }

    @Override
    public byte[] nextMsg() throws IOException {
        ByteArrayOutputStream messageBuffer=new ByteArrayOutputStream();
        int nextByte;
        //读取流中的每一个字节,直到遇到定界符
        while ((nextByte=in.read())!=DELIMITER){
            if (nextByte==-1){
                //如果遇到定界符之前就到了流的终点
                if (messageBuffer.size()==0){
                    return null;
                }else {
                    //如果存入缓存区之前有数据,抛出异常
                    throw new EOFException("Non-empty message without delimiter");
                }
            }
            //将无定界符的字节写入消息缓存区
            messageBuffer.write(nextByte);
        }
        //将消息缓存区的内容以字节数组的形式返回        return messageBuffer.toByteArray();

雪峰 Java 教程 Java教程 Java快速入门 Java简介 安装JDK 第一个Java程序 Java代码助手 使用IDE 使用IDE练习插件 Java程序基础 Java程序基本结构 变量和数据类型 整数运算 浮点数运算 布尔运算 字符和字符串 数组类型 流程控制 输入和输出 if判断 switch多重选择 while循环 do while循环 for循环 break和continue 数组操作 遍历数组 数组排序 多维数组 命令行参数 面向对象编程 面向对象基础 方法 构造方法 方法重载 继承 多态 抽象类 接口 静态字段和静态方法 包 作用域 classpath和jar 模块 Java核心类 字符串和编码 StringBuilder StringJoiner 包装类型 JavaBean 枚举类 BigInteger BigDecimal 常用工具类 异常处理 Java的异常 捕获异常 抛出异常 自定义异常 使用断言 使用JDK Logging 使用Commons Logging 使用Log4j 使用SLF4J和Logback 反射 Class类 访问字段 调用方法 调用构造方法 获取继承关系 动态代理 注解 使用注解 定义注解 处理注解 泛型 什么是泛型 使用泛型 编写泛型 擦拭法 extends通配符 super通配符 泛型和反射 集合 Java集合简介 使用List 编写equals方法 使用Map 编写equals和hashCode 使用EnumMap 使用TreeMap 使用Properties 使用Set 使用Queue 使用PriorityQueue 使用Deque 使用Stack 使用Iterator 使用Collections IO File对象 InputStream OutputStream Filter模式 操作Zip 读取classpath资源 序列化 Reader Writer PrintStream和PrintWriter 日期与时间 基本概念 Date和Calendar LocalDateTime ZonedDateTime DateTimeFormatter Instant 最佳实践 单元测试 编写JUnit测试 使用Fixture 异常测试 条件测试 参数化测试
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值