Tag: java

RabbitMQ和通道和连接的关系

RabbitMQ Java客户端具有以下概念: Connection – 连接到RabbitMQ服务器实例 Channel – ??? 消费者线程池 – 消耗RabbitMQ服务器队列中的消息的线程池 队列 – 按FIFO顺序保存消息的结构 我试图理解这种关系, 更重要的是他们之间的关系。 我还不太确定一个Channel是什么,除了这是你发布和消费的结构,而且是从一个开放的连接创build的。 如果有人能向我解释“频道”代表什么,这可能有助于澄清一些事情。 频道和队列之间的关系是什么? 是否可以使用同一个通道与多个队列通信,还是必须是1:1? 队列和消费者池之间的关系是什么? 多个消费者可以订阅相同的队列吗? 多个队列可以被同一个消费者使用吗? 或者是1:1的关系? 在此先感谢您的帮助!

Java Queue的实现,哪一个?

来自Javadoc: ConcurrentLinkedQueue是许multithreading将共享访问共享集合的合适select。 该队列不允许空元素。 ArrayBlockingQueue是一个经典的“有界缓冲区”,其中一个固定大小的数组包含生产者插入的元素,并由消费者提取。 这个类支持一个可选的公平策略来sorting等待的生产者和消费者线程 LinkedBlockingQueue通常比基于arrays的队列具有更高的吞吐量,但是在大多数并发应用程序中性能较差。 我有两个场景,一个需要队列支持许多生产者(线程使用它)与一个消费者,另一个是相反的方式。 我不明白是否应该使用ConcurrentLikedQueue或其他(数组或LinkedList实现)。 Wherent'所有这些实现应该是并发的? 我的意思是,有人可以解释我ConcurrentLikedQueue和LinkedBlockingQueue什么区别吗? 另外, ArrayBlockingQueue的可选公平策略是什么?

Java规则引擎的优缺点

采用Java规则引擎JESS和Drools有什么优点和缺点? 还有其他玩家吗? 我知道Drools是开源的,JESS不是,但是他们在其他方面比如易用性,性能,与代码集成度如何呢?

Java中variables的内存地址

请看下面的图片。 当我们使用new关键字在java中创build一个对象时,我们从OS获取一个内存地址。 当我们写出out.println(objName)我们可以看到一个“特殊的”string作为输出。 我的问题是: 这是什么输出? 如果是由操作系统给我们的内存地址: a)如何将此string转换为二进制文件? b)如何获得一个整数variables地址?

我需要persistence.xml中的<class>元素吗?

我有非常简单的persistance.xml文件: <?xml version="1.0" encoding="UTF-8"?> <persistence version="1.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"> <persistence-unit name="eventractor" transaction-type="RESOURCE_LOCAL"> <class>pl.michalmech.eventractor.domain.User</class> <class>pl.michalmech.eventractor.domain.Address</class> <class>pl.michalmech.eventractor.domain.City</class> <class>pl.michalmech.eventractor.domain.Country</class> <properties> <property name="hibernate.hbm2ddl.auto" value="validate" /> <property name="hibernate.show_sql" value="true" /> </properties> </persistence-unit> </persistence> 它的工作。 但是,当我删除<class>元素应用程序没有看到实体(所有的类都用@Entity注释)。 有没有自动机制来扫描@Entity类?

将Gradle支持添加到IntelliJ Project的最佳方法

我已经查了很多,并没有find最好的解决scheme来将现有的IntelliJ项目转换为Gradle。 我在团队环境中工作,我们目前共享.ipr文件,因为我们有一些跟踪的构buildconfiguration。 我们最终会摆脱那些赞成Gradle的人,但是在Gradle转换完成之前,我不能把事情弄得太多。 另外,我们的Java源文件是标准的,位于src目录的根目录,而不是src / main / java。 有没有一种方法可以将Gradle添加到我的项目中,这不会让我删除并重新创buildIntelliJ项目,并且在执行Git pull时不会将所有人都搞砸?

方法签名中的Java“params”?

在C#中,如果你想要一个方法有一个不确定数量的参数,你可以使方法签名中的最后一个参数成为一个params这样方法参数看起来就像一个数组,但是允许使用该方法的每个人传递参数键入作为来电者想要的。 我相当确定Java支持类似的行为,但我无法find如何做到这一点。

最终静态和静态最终的区别

我发现了一个代码就像声明的代码 private final static String API_RTN_SUCCESS = "0"; private final static String API_RTN_ERROR = "1"; public static final String SHARED_PREFERENCE_CONFIG = "shared_preference_config"; public static final String STARTUP_SETTING_KEY = "startup_setting"; 他们之间有什么不同还是他们是一样的? 或者是private还是public ?

如何从一个string中加载XML中的org.w3c.dom.Document?

我有一个完整的XML文档在一个string,并希望一个Document对象。 谷歌变成各种垃圾。 什么是最简单的解决scheme? (在Java 1.5中) 解决scheme感谢Matt McMinn ,我已经解决了这个问题。 它对我来说具有正确的input灵活性和exception粒度。 (很好地知道错误是否来自格式错误的XML – SAXException – 或只是错误的IO – IOException 。) public static org.w3c.dom.Document loadXMLFrom(String xml) throws org.xml.sax.SAXException, java.io.IOException { return loadXMLFrom(new java.io.ByteArrayInputStream(xml.getBytes())); } public static org.w3c.dom.Document loadXMLFrom(java.io.InputStream is) throws org.xml.sax.SAXException, java.io.IOException { javax.xml.parsers.DocumentBuilderFactory factory = javax.xml.parsers.DocumentBuilderFactory.newInstance(); factory.setNamespaceAware(true); javax.xml.parsers.DocumentBuilder builder = null; try { builder = factory.newDocumentBuilder(); } catch […]

无法在Windows上安装Maven:“JAVA_HOME被设置为无效的目录”

我遵循了Maven的教程 ,但我仍然无法在Windows上安装Maven。 当我在命令提示符下运行以下命令时: E:\Documents and Settings\zach>mvn –version 我得到: 'mvn' is not recognized as an internal or external command, operable program or batch file. 我导航到Maven安装文件夹,运行mvn –version ,得到: E:\java resources\apache-maven-2.2.0\bin>mvn –version ERROR: JAVA_HOME is set to an invalid directory. JAVA_HOME = "E:\Sun\SDK\jdk\bin" Please set the JAVA_HOME variable in your environment to match the location of your Java […]