草庐IT

read_buffer

全部标签

java - 在 Java 中扩展 Protocol Buffers

我在访问扩展ProtocolBuffer成员时遇到问题。这是场景:MessageFoo{optionalinti=1;}messageBar{extendFoo{optionalintj=10001;}}我的任何其他原型(prototype)中都没有Bar消息。如何在Java中获取Bar.j?我发现的所有示例都需要在消息中使用Bar。谢谢! 最佳答案 ProtocolBuffer中的扩展并不一定像您期望的那样工作,即它们不匹配Java继承机制。针对您的问题,我创建了以下foobar.proto文件:packagetest;messa

具有多线程的 Java NIO SocketChannel.read()

我正在使用带有一个选择线程和多个工作线程(用于执行真正的读/写)的JavaNIO实现一个简单的文件服务器。代码的主要部分如下所示:while(true){intnum=selector.select();if(num>0){Iteratorkeys=selector.selectedKeys().iterator();finalSelectionKeykey=keys.next();keys.remove();if(key.isValid()){if(key.isAcceptable()){accept(key);}elseif(key.isReadable()){performRea

java - Java Protocol Buffers 能否在重复字段的列表 getter 上返回 null?

假设您有一个重复字段。messageFoo{optionalint32val=1;}messageBar{repeatedFoofoo=1;}这将生成方法ListgetFooList()有没有getFooList会返回null的情况?或者它是否已经返回一个列表,即使它是空的? 最佳答案 不,不存在返回null的情况。事实上,Javaprotobuf生成的类中的任何字段访问器都不会返回null;如果该字段不存在,它们总是返回默认值。同样,setter不允许您设置null。 关于java-J

java - 为什么 Netty 4 "proxy"示例必须将 channel "AUTO_READ"设置为 false

在Netty4中"proxy"example,channel自动读取选项已被禁用:serverBootStrap.group(bossGroup,workerGroup)....childOption(ChannelOption.AUTO_READ,false)如果注释childOption(ChannelOption.AUTO_READ,false),代理示例将无法工作。更详细地说,在HexDumpProxyFrontendHandler类的方法channelRead中,outboundChannel将始终处于非Activity状态。我研究了Netty源代码,发现“自动读取”会影响类

java - Protocol Buffer : get byte array from ByteString without copying

假设我有一个方法voidfoo(byte[]bytes)需要一个字节数组作为它的参数。但是,Protobuf中字节数组的Java类型是ByteString。我可以使用byte[]toByteArray()获取字节数组。但问题是这种方法使用copy来构建一个新的数组,代价比较大。我宁愿它直接返回底层数组,或者返回一个View。是否有任何API,或者性能损失是可以接受的? 最佳答案 通常这是不可能的,因为在ByteString的某些子类中可能没有这样的数组。BoundedByteString可以包含更大的数组,因此需要复制才能获得正确大

java - Jboss hibernate 工具 : Reading error schema - Probably a JDBC driver Issue

您好,我正在尝试使用JBossHibernate工具进行逆向工程。我正在使用eclipseluna和来自eclipse市场的最新hibernatejboss工具。当我尝试配置hibernate工具配置时,配置完成后,当我伸展树(SplayTree)并展开database节点时,它会生成以下错误:堆栈跟踪:org.hibernate.exception.SQLGrammarException:Couldnotgetlistofsuggestedidentitystrategiesfromdatabase.ProbablyaJDBCdriverproblem.atorg.hibernate

java - 输入 stream.read 返回 0 或 -1?

有什么区别byte[]buffer=newbyte[1024];//this:if(inputStream.read(buffer)>0){/*...*/}//and:if(inputStream.read(buffer)!=-1){/*...*/}都可以判断网络流终止吗? 最佳答案 InputStream.read()的Javadocs说:Ifthelengthofbiszero,thennobytesarereadand0isreturned在正常使用中,这种情况永远不会发生,因此明确测试这种情况没有多大意义。(如果您想避免永远

java - Protocol Buffer Java RPC 栈

根据this维基百科词条:“ProtocolBuffers与Facebook的Thrift协议(protocol)非常相似,只是它不包含用于定义服务的具体RPC堆栈。自从ProtocolBuffers开源以来,出现了许多RPC堆栈来填补这一空白”但是没有引用RPC栈的例子。谁能建议基于Java的RPC堆栈实现? 最佳答案 如果你想要基于Java的RPC堆栈,它是RMI.但是,它不能很好地跨平台工作。我一直在使用ProtoBuf做RPC。您几乎可以通过将protobuf消息包装在另一个定义服务或调用的protobuf中来模拟RPC堆栈

java - Protocol Buffer 3 : Enums as keys in a map

枚举不允许用作映射中的键。这里的PaxType是一个枚举,不允许用作键。enumPaxType{ADULT=0;CHILD=1;INFANT=2;}messageFlightData{mapfareType=1;} 最佳答案 这是不允许的,因为它不能很好地与proto3开放枚举语义兼容。例如,在Java中,如果您有一个Map,则键只能是定义的值之一。如果您碰巧从远程客户端/服务器接收到不在定义值集中的枚举键值,则无法将其放入Map中。此限制迫使我们要么删除具有未知枚举键的映射条目(这违反了proto3开放枚举语义),要么禁止枚举作为

java - JAX-RS Jersey 客户端 : Reading the Response with status code

我使用此代码通过Jersey客户端调用JerseyJAX-RS服务。publicstaticvoidmain(String[]args){ClientConfigconfig=newDefaultClientConfig();Clientclient=Client.create(config);WebResourceservice=client.resource(getBaseURI());Stringmsg=service.path("rest").path("ExceptionDemo").path("user").queryParam("id","001").get(String