草庐IT

Java - 通过 channel 传输大文件 - NIO

我必须使用NIO通过ServerSocket传输约100MB的数据,但我不知道如何在不在任何地方中断传输/保持传输状态的情况下执行此操作。我的第一个想法是发送文件的大小,显然我不能发送这么大的文件,因为它甚至不能一次放在RAM上。然后我想,为什么不直接转账直到什么都没有收到,但那时候问题就来了。即使我一直在写服务器端数据FileChannelfc=newFileInputStream(f).getChannel();ByteBufferbuffer=ByteBuffer.allocate(1024);while(fc.read(buffer)>0){buffer.flip();whil

java - 如何序列化 ByteBuffer

我希望使用RMI跨网络发送java.nio.ByteBuffer,但是ByteBuffer不可序列化。我试过以下自定义类无济于事:publicclassNetByteBufferimplementsjava.io.Serializable{ByteBufferbuffer;publicNetByteBuffer(ByteBufferbuffer){this.buffer=buffer;}publicByteBuffergetByteBuffer(){returnthis.buffer;}客户端仍然得到一个不可序列化的异常。有什么想法吗?谢谢 最佳答案

java - CharBuffer.put() 没有工作

我尝试使用CharBuffer.put()函数将一些字符串放入CharBuffer但缓冲区留空。我的代码:CharBuffercharBuf=CharBuffer.allocate(1000);for(inti=0;i我尝试在allocate(1000)之后使用clear()或rewind()但这并没有改变结果。 最佳答案 添加对rewind()的调用就在循环之后。 关于java-CharBuffer.put()没有工作,我们在StackOverflow上找到一个类似的问题:

java - Java 的 System.out.print() 会一直缓冲到 println() 吗?

我今天无意中听到关于System.out.print()的争论。一个人声称,由于print()不包括终止\n,它写入的缓冲区最终将填满并开始丢失数据。另一个人声称他们一直在为他们所有的Java程序使用System.out.print()并且从未遇到过这个问题。第一人称对吗?如果stdout已满,System.out.print()是否可以开始阻止或丢弃数据?是否有导致此问题的代码示例? 最佳答案 当System.out.print使用的缓冲区填满时,输出将写入文件(或连接到程序标准输出流的终端或其他数据目标),导致一个空缓冲区。在不

java - 对于长度变化很大的输入,最佳 StringBuffer 初始容量是多少?

大家下午好,我正在使用java.lang.StringBuilder存储一些字符。我不知道我要提前存储多少个字符,除了:60%的情况下,它只有(恰好)7个字符39%的时间是(大约)3500个字符1%的时间,大约是20k个字符我们如何计算应该使用的最佳初始缓冲区长度?目前我正在使用newjava.lang.StringBuilder(4000)但那只是因为我以前懒得想。 最佳答案 这里有两个因素:时间和内存消耗。该时间主要受java.lang.AbstractStringBuilder.expandCapacity()调用次数的影响。

java - 是否可以将 Process stdout InputStream 读取到 NIO ByteBuffer 中?

是否可以使用NIO来处理来自进程的标准输出?我让它与java.io一起工作,但这是一种练习,可以更多地了解NIO并探索性能改进的可能性。基本上,我想尽可能快地将大量文本从stdout流式传输到缓冲区而不阻塞,然后稍后处理该缓冲区的内容。问题是,我似乎无法找出合适的巫术来让它与NIO一起工作。这就是我现在所在的位置:ProcessBuilderpb=newProcessBuilder(...);Processp=pb.start();stdout=newStreamConsumer(p.getInputStream());newThread(stdout).start();//other

java - 如何使用 Java 将文件从 Zip 文件读取到内存?

我从SUN站点(http://java.sun.com/developer/technicalArticles/Programming/compression/)找到示例,但它返回BufferedOutputStream。但我想将ZipEntry文件作为InputStream获取,然后处理下一个文件。那可能吗?我的程序无法访问硬盘,因此它甚至无法临时保存文件。importjava.io.*;importjava.util.zip.*;publicclassUnZip{finalintBUFFER=2048;publicstaticvoidmain(Stringargv[]){try{B

基于美团Leaf-Segment的双buffer方案实现序列号生成器

业务背景    有时项目中对于流水号有一些特殊的需求。比如,和业务A有关数据,我们在落库时想要给每条数据添加一个流水号字段,用于作为全局唯一标识。流水号格式规则如下,如:BTA(业务A代号)+年月日(20221208)+序列号。并且对序列号的长度有要求,如序列号要求为5位,即从00001到99999,当序列号达到99999后,再次获取则继续从00001开始累加循环。流水号的形式如TX2022120800001。在此之前需要对业务A有关数据每日的数据量进行评估,以上述为例,若一天的单据量超过99999,再次循环可能会造成流水号重复,以致流水号不唯一,所以序列号最大值可以设的稍大一位。初期方案最开

java - BufferedWriter 在 Java 中是如何工作的

我经常将文本输出到文件。我想知道:BufferedWriter是如何工作的?当我调用writer.write(text)时,它是否将文本写入文件?如果不写入文本,是否需要使用flush函数来写入数据?例如:Filefile=newFile("statistics.txt");if(!file.exists()){file.createNewFile();}else{file.delete();file.createNewFile();}FileWriterfileWritter=newFileWriter(file.getAbsoluteFile(),true);BufferedWri

Java NIO - 内存映射文件

我最近遇到了这个article它很好地介绍了内存映射文件以及如何在两个进程之间共享它。以下是读取文件的进程的代码:importjava.io.File;importjava.io.FileNotFoundException;importjava.io.IOException;importjava.io.RandomAccessFile;importjava.nio.MappedByteBuffer;importjava.nio.channels.FileChannel;publicclassMemoryMapReader{/***@paramargs*@throwsIOExceptio