- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
下面是我的代码,它替换了 DataInputStream 以包装 InputStream,但除了读取大端类型的常规方法之外,还提供了额外的方法来读取小端数据类型。如果您愿意,请随意使用它。
我有以下几点保留意见。注意不改变功能的方法(读取大端类型的函数)。我无法将 DataInputStream 实现为基类并使用其方法,如 read()、readInt()、readChar() 等?
我的类层次结构在这里似乎有点奇怪。这样合适吗?
像 readUTF() 或 readLine() 这样的其他类型是否需要小端版本?或者这对特定程序来说是主观的?
Java 是如何存储 boolean 类型的?这也是字节顺序的主观因素吗?
感谢您满足我的好奇心:)
import java.io.*;
/**
* Replacement for a DataInputStream that provides both little and big endian reading capabilities for convenience without need to implement a ByteBuffer
* @author Bill (unspecified.specification@gmail.com)
*/
public class EndianInputStream extends InputStream implements DataInput {
private DataInputStream dataInStream;
private InputStream inStream;
private byte byteBuffer[];
/**
* Constructor to wrap InputStream for little and big endian data
* @param refInStream Inputstream to wrap
*/
public EndianInputStream(InputStream refInStream) {
inStream = refInStream;
dataInStream = new DataInputStream(inStream);
byteBuffer = new byte[8]; // Largest data type is 64-bits (8 bytes)
}
@Override
public int available() throws IOException {
return dataInStream.available();
}
@Override
public final int read(byte refBuffer[], int offset, int readLen) throws IOException {
return inStream.read(refBuffer, offset, readLen);
}
@Override
public int read() throws IOException {
return inStream.read();
}
@Override
public final int readUnsignedByte() throws IOException {
return dataInStream.readUnsignedByte();
}
@Deprecated
@Override
public final String readLine() throws IOException {
return dataInStream.readLine();
}
@Override
public final String readUTF() throws IOException {
return dataInStream.readUTF();
}
@Override
public final void close() throws IOException {
dataInStream.close();
}
@Override
public final void readFully(byte refBuffer[]) throws IOException {
dataInStream.readFully(refBuffer, 0, refBuffer.length);
}
@Override
public final void readFully(byte refBuffer[], int offset, int readLen) throws IOException {
dataInStream.readFully(refBuffer, offset, readLen);
}
@Override
public final int skipBytes(int n) throws IOException {
return dataInStream.skipBytes(n);
}
@Override
public final boolean readBoolean() throws IOException {
return dataInStream.readBoolean();
}
@Override
public final byte readByte() throws IOException {
return dataInStream.readByte();
}
@Override
public final float readFloat() throws IOException {
return Float.intBitsToFloat(readInt());
}
@Override
public final double readDouble() throws IOException {
return Double.longBitsToDouble(readLong());
}
@Override
public final short readShort() throws IOException {
return dataInStream.readShort();
}
@Override
public final int readUnsignedShort() throws IOException {
return dataInStream.readUnsignedShort();
}
@Override
public final long readLong() throws IOException {
return dataInStream.readLong();
}
@Override
public final char readChar() throws IOException {
return dataInStream.readChar();
}
@Override
public final int readInt() throws IOException {
return dataInStream.readInt();
}
/**
* Reads floating point type stored in little endian (see readFloat() for big endian)
* @return float value translated from little endian
* @throws IOException if an IO error occurs
*/
public final float readLittleFloat() throws IOException {
return Float.intBitsToFloat(readLittleInt());
}
/**
* Reads double precision floating point type stored in little endian (see readDouble() for big endian)
* @return double precision float value translated from little endian
* @throws IOException if an IO error occurs
*/
public final double readLittleDouble() throws IOException {
return Double.longBitsToDouble(readLittleLong());
}
/**
* Reads short type stored in little endian (see readShort() for big endian)
* @return short value translated from little endian
* @throws IOException if an IO error occurs
*/
public final short readLittleShort() throws IOException {
dataInStream.readFully(byteBuffer, 0, 2);
return (short)((byteBuffer[1] & 0xff) << 8 | (byteBuffer[0] & 0xff));
}
/**
* Reads char (16-bits) type stored in little endian (see readChar() for big endian)
* @return char value translated from little endian
* @throws IOException if an IO error occurs
*/
public final char readLittleChar() throws IOException {
dataInStream.readFully(byteBuffer, 0, 2);
return (char)((byteBuffer[1] & 0xff) << 8 | (byteBuffer[0] & 0xff));
}
/**
* Reads integer type stored in little endian (see readInt() for big endian)
* @return integer value translated from little endian
* @throws IOException if an IO error occurs
*/
public final int readLittleInt() throws IOException {
dataInStream.readFully(byteBuffer, 0, 4);
return (byteBuffer[3]) << 24 | (byteBuffer[2] & 0xff) << 16 |
(byteBuffer[1] & 0xff) << 8 | (byteBuffer[0] & 0xff);
}
/**
* Reads long type stored in little endian (see readLong() for big endian)
* @return long value translated from little endian
* @throws IOException if an IO error occurs
*/
public final long readLittleLong() throws IOException {
dataInStream.readFully(byteBuffer, 0, 8);
return (long)(byteBuffer[7]) << 56 | (long)(byteBuffer[6]&0xff) << 48 |
(long)(byteBuffer[5] & 0xff) << 40 | (long)(byteBuffer[4] & 0xff) << 32 |
(long)(byteBuffer[3] & 0xff) << 24 | (long)(byteBuffer[2] & 0xff) << 16 |
(long)(byteBuffer[1] & 0xff) << 8 | (long)(byteBuffer[0] & 0xff);
}
/**
* Reads unsigned short type stored in little endian (see readUnsignedShort() for big endian)
* @return integer value representing unsigned short value translated from little endian
* @throws IOException if an IO error occurs
*/
public final int readLittleUnsignedShort() throws IOException {
dataInStream.readFully(byteBuffer, 0, 2);
return ((byteBuffer[1] & 0xff) << 8 | (byteBuffer[0] & 0xff));
}
}
最佳答案
readBoolean()
读取单个字节。 readLine()
读取单个字节并将每个字节转换为 char
。
readUTF()
读取修改后的 UTF-8(其代码单元大小为一个八位字节)。 UTF-8 有 no endianness .
这些方法没有字节序问题。
关于设计,考虑类型是否需要是 InputStream
以及 ByteBuffer
是否是可能有用。如果您没有使用标记/重置和 Closeable
等功能您可能不会公开新类型:
public class Bytes {
public static DataInput littleEndian(final DataInput decorated) {
class LittleInput implements DataInput {
private ByteBuffer buffer = ByteBuffer.allocate(8);
public int readInt() throws IOException {
buffer.clear();
buffer.order(ByteOrder.BIG_ENDIAN)
.putInt(decorated.readInt())
.flip();
return buffer.order(ByteOrder.LITTLE_ENDIAN)
.getInt();
}
//TODO: other methods
}
return new LittleInput();
}
}
我注意到流行的 Guava 库已经有 LittleEndianDataInputStream .
关于Java : DataInputStream replacement for endianness,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8028094/
我正在制作一个简单的 TCP/IP 套接字应用 这样做有什么不同: DataInputStream in = new DataInputStream(clientSocket.getInputStre
1. 概述 在这个例子中,我们将用DataInputStream类来读取一个文件。数据输入流让应用程序以独立于机器的方式从底层输入流读取原始的Java数据类型。一个应用程序使用数据输出流来写数据,这些
我对 Java 编程和堆栈溢出都很陌生,今天早上我在遵循简单的代码时遇到了很大的麻烦。它有 3 个选项,将新用户添加到二进制文件,列出其中的每个用户并搜索特定用户以显示与其相关的所有其他数据(姓氏和出
我正在实现一个简单的客户端/服务器读取器,并使用 DataInputStream 将所有内容读取为字节,然后稍后进行解析。 这是我的阅读代码: String line; String requestS
我的 DataInputStream 有问题,它没有完全读取文件,经常(每约 33000 个字符)跳过 2-3 个字符。我正在尝试将文件(8 mb)解析为 json,并且由于字符串中跳过的字符,我无法
我在 Java 中使用 DataInputStream 和 DataOutputStream 时遇到了一个问题,如果没有一些非常愚蠢的措施,我就无法解决这个问题,并且想知道是否有人知道更好的方法(我非
我想从二进制文件构建 HashMap 。该二进制文件具有以下结构:第一个整数表示我必须从流中读取的整数数量,以便构建 HashMap ,后跟键/值对。 因此,对于具有三个值的 HashMap ,我总共
我正在尝试编写一个外部合并排序,但如果我已经关闭了第一个数据输入流,我似乎无法为文件创建第二个数据输入流。例如: public class test { private static Data
正如标题所说,如果可用字节多于缓冲区大小,并且在第一次读取时丢失了一些字节,DataInputStream.read() 是否可以覆盖以前读取的字节? 对等点之间交换固定大小的数据包,并且套接字上可能
我正在学习用 Java 进行读写,并且遇到了一个简单的练习。该程序从 2 个 txt 文件中读取,每个文件都包含行中的数字。它将每行数字相乘的结果写入输出文件。例如。 file 1 row 1 : 1
我正在做一项家庭作业,我必须连接到 http 服务器并使用套接字编程下载 html 文件和图像文件。 我做得很好,能够正确下载和编写 html 和图像文件。但是当我编辑代码以满足作业的要求时(网页必须
这个问题真让我头疼。非常简单的场景。使用 DataInputStream 通过 TCP 发送和接收文件。 这是写法 private boolean send(File file) { try
我有一个套接字客户端,每当我尝试从套接字读取输入流时,它都会挂起。 DataInputStream dis = new DataInputStream(socket.getInputStream())
我目前正在制作一个消息传递应用程序,稍后我还将为其添加加密。我有一台打开套接字并等待客户端连接的服务器。客户端连接后,它会为该客户端创建一个新线程。然后等待消息等。 我遇到的问题是,当我尝试将公钥指数
如果我在 DataInputStream 上调用 read(),它会占用 CPU 周期等待数据,还是会产生当前线程并被中断信号唤醒,表明数据已到达? 我的动机是确定流读取器是否需要在其自己的线程中。占
我的Java项目(我是客户端)包括通过TCP套接字连接发送请求和读取响应。通过套接字,我创建一个输出和输入流,分别用于发送和接收数据。一切正常,除了消息的结尾,即我通过 DataOutputStrea
我正在为学校作业创建一个文件服务器应用程序。我目前拥有的是一个简单的 Client 类,它通过 TCP 发送图像,还有一个 Server 类接收图像并将其写入文件。 这是我的客户端代码 import
我有一个要加载的文件格式,其中包含 OpenGL 对象的原始数据。 一切都很好,但数据是小端编码的。 是否有一个 java 类可以完成 DataInputStream 的确切工作但使用小端,还是我必须
我必须创建一个应用程序来检索网络上的 xml 文件,并将其存储在 Blackberry 手机的 SD 卡上。 xml 文件由 cron 作业更新。因此,如果数据已添加到此 xml 文件,我希望应用程序
我用java编写了以下程序来使用DataInput\Output Stream复制文件。 import java.io.*; public class FileCopier { public
我是一名优秀的程序员,十分优秀!