草庐IT

io_stream

全部标签

java - 磁盘空间不足会导致 java.lang. io。 EOF异常

今天在java序列化和反序列化中遇到了奇怪的行为(“奇怪”是因为我不明白)我正在对linux共享目录中的对象进行序列化和反序列化。虽然序列化一切都没有任何问题,但是当我试图反序列化同一个文件时它抛出java。io。EOFException。此外,反序列化仅对这个新创建的文件失败,并且对该目录中的所有其他旧文件有效。所以我在互联网上进行了搜索,发现一个帖子说磁盘空间不足也可能是导致此错误的原因。所以我清理了一些临时文件,瞧,它起作用了。我不明白低磁盘空间如何只影响反序列化而不影响序列化?我正在使用apachecommonsSerializationUtils类。下面是序列化和反序列化的代

java - 如何使用 Streams 将二维列表转换为一维列表?

我试过这段代码(list是ArrayList>):list.stream().flatMap(Stream::of).collect(Collectors.toList());但它什么也没做;该列表仍然是一个二维列表。如何将此二维列表转换为一维列表? 最佳答案 您仍然收到列表的原因是因为当您申请Stream::of它正在返回现有流的新流。那是你执行Stream::of的时候这就像有{{{1,2}},{{3,4}},{{5,6}}}然后当你执行flatMap就像这样做:{{{1,2}},{{3,4}},{{5,6}}}->flatMa

Java 8 Stream distinct 不起作用

这就是我正在做的:Listscores=Stream.concat(oldEntries.stream(),newEntries.stream()).sorted().distinct().limit(maxSize).collect(Collectors.toList());我期待一个没有任何重复项的排序列表,但有时列表中有重复项。我重写了hashCode和equals方法,我还观察到这些方法每次都返回正确的值。任何人都可以看到我的流有什么问题吗?这是我的equals()和hashCode()它们是由IDEA自动生成的:..privateintuserId;privateintlev

java - 是否可以创建在单个操作中计算其元素的 Stream 实现

问:是否可以创建Stream实现,在单个操作中对它们的元素进行计数,而不是对流中的每个元素进行计数?当我试图比较列表中的两种方法时,我想到了这个:大小()count()Stream::count终端操作计算流中元素的数量。操作的复杂度通常为O(N),这意味着子操作的数量与Stream中的元素数量成正比。List::size方法的复杂度为O(1),这意味着无论List中的元素数量如何,size()方法将在常数时间内返回。Listlist=IntStream.range(0,100).boxed().collect(toList());System.out.println(list.siz

java - ANTLR @header、@parser、superClass 选项和基本文件 io (Java)

我想对基本文件io(Java)使用解析器操作,例如。G。ANTLR语法中的PrintWriter。我必须使用superClass选项还是可以使用@header?在这两种情况下,我如何声明PrintWriter对象以及我必须如何处理异常? 最佳答案 选项superClass=...用于让您的Parser扩展自定义类。所以,我认为这不是您想要的。@header部分中的所有内容都将放在Parser类的开头。这用于导入类:@header{importjava.io.PrintWriter;}请注意,@header{...}是@parser:

java - 将对象从 java.nio.file.Path 转换为 java.io.File

这个问题在这里已经有了答案:Java:PathvsFile(8个答案)关闭4年前。我想知道是否有可能以某种方式将定义为java.nio.file.Path的对象转换为java.io.File

java - 避免 "cannot retry due to server authentication, in streaming mode"错误,不涉及任何 CXF

我已经在很多地方搜索过处理过这个HttpRetryException问题的其他人,但我发现的所有人都遇到过一些名为CXF的apache服务,我没有使用它。我使用的是java.net.HttpURLConnection。我创建一个连接,将setRequestProperty用于“授权”,获取输出流,写入一堆字节,然后尝试读取回复输入流。大多数时候这都有效,但有时我会遇到上述异常。我无法避免流式传输,因为有时我需要写入比内存中所能存储的更大的文件,而且无论如何,我发现的大多数搜索结果都表明这不是真正的问题。他们通常按照bindingProvider.getRequestContext().

java - java8 Stream的filter()和map()方法是否使用迭代?

我在Person.java文件中有一个POJO:publicclassPerson{privateStringname;privateintage;publicPerson(Stringn,inta){name=n;age=a;}publicStringgetName(){returnname;}publicintgetAge(){returnage;}publicbooleanisAdult(){returngetAge()>=18;}}然后我有一个Demo.java文件,它创建一个人员列表并使用流来过滤和打印列表中的内容:importjava.util.*;publicclassD

Java 8 Streams - 分组为单个值

这个问题在这里已经有了答案:Java8ListintoMap(23个回答)关闭2年前。我目前正在使用List>我试图在map中对各种键进行分组。这似乎可以很好地使用Java8Stream小号:Map>>>collect=list.stream().collect(Collectors.groupingBy(item->item.get("key1"),Collectors.groupingBy(item->item.get("key2"))));不出所料,这给了我一个Map>>>这适用于可能的分组结果大于1的情况。例如,我有各种示例,其中完成的分组将总是导致最低级别列表中的单个项目。行

基于谓词的Java 8 Stream indexOf方法

这个问题在这里已经有了答案:StreamWaytogetindexoffirstelementmatchingboolean(6个回答)关闭4年前。我刚刚遇到这样的情况,我需要知道一个元素在列表中的索引(位置),但只有一个谓词表达式来标识该元素。我找了一个类似的Stream函数intindex=list.stream().indexOf(e->"TESTNAME".equals(e.getName()));但无济于事。当然,我可以这样写:intindex=list.indexOf(list.stream().filter(e->"TESTNAME".equals(e.getName()