草庐IT

public-activity

全部标签

java - 使用 G1 时,大量 Activity 实例的分配性能会降低吗?

在将我们的一些应用程序从CMS迁移到G1时,我注意到其中一个应用程序的启动时间延长了4倍。由于GC循环导致的应用程序停止时间不是原因。在比较应用程序行为时,我发现这个应用程序在启动后携带了高达2.5亿个Activity对象(在12G的堆中)。进一步调查表明,应用程序在前500万次分配中速度正常,但随着Activity对象池的增大,性能越来越下降。进一步的实验表明,一旦达到一定的Activity对象阈值,使用G1时新对象的分配确实会变慢。我发现将Activity对象的数量加倍似乎会使该分配所需的时间增加2.5倍左右。对于其他GC引擎,该系数仅为2。这确实可以解释减速。不过,有两个问题让我

java - get 在没有 Activity 事务的情况下无效 - hibernate 5

即使我已手动启动交易,我仍不断收到此错误。Sessionsession=HibernateUtil.getSessionFactory().getCurrentSession();transaction=session.getTransaction();if(!transaction.isActive()){transaction=session.beginTransaction();}accessToken=session.get(OAuthAccessToken.class,token);hibernate.cfg.xmltrue520300503000org.hibernate.

java - 除非那些内部类也被声明为静态,否则我们不能在 [public] 内部类中声明静态方法的确切原因是什么?azi

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Whycantwehavestaticmethodinaninnerclass?大家好,在Java中,我们不能在[public]内部类中声明静态方法的确切原因是什么,除非这些内部类也被声明为静态的?顶级类可以拥有任意数量的静态方法而不需要任何特殊的修饰符

java - 为什么 java.awt.Dimension 有公共(public)变量?

public变量的类在封装中被认为是弱的,这不是一个糟糕的设计实践吗?如果是这样,为什么java.awt.Dimension有2个公共(public)变量width和height? 最佳答案 我认为公开公共(public)字段并不违反封装本身。封装是实体的属性,实体内部隐藏着复杂的内部结构。这个复杂的结构不能直接访问,因此没有被破坏的风险。它只能通过公共(public)方法访问,这使得它们可以很好地工作并且不会破坏复杂的内部结构。例如,我们无法直接访问HashMap的哈希表,也无法破坏它。我们只使用get和put方法来正确处理哈希表

java - 我应该把 public static void main(String[] args) 方法放在哪里?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭8年前。Improvethisquestion我认为它对程序输出没有任何影响,但是我应该把它放在什么类中publicstaticvoidmain(String[]args){//...}我程序中的方法?创建一个单独的类或将它放在一个做其他事情的类中是更好的形式吗?如果我应该把它放在一个做其他事情的类中,哪个类?有关系吗?这实际上只是约定俗成的事情。通常我创建一个单独的类或将其放在处理gui的类中,但我想知道正确的做法。

java - 用于从数据库读取属性的 apache 公共(public)配置的替代方案

我刚刚发现Apachecommons-configuration可以从DataSource读取属性,但它不会缓存它们。我的应用程序需要多次读取属性,每次访问数据库都很慢。我有一个Camel应用程序,它将所有消息发送到以我的自定义bean结尾的路由。这些bean是使用作用域原型(prototype)创建的(我相信OOP),它们将/需要读取一些属性和数据源(从属性url/name/etc读取),这些数据源依赖于来自SQL数据库的当前用户。我收到的每条消息都会创建一个bean,因此会重新读取属性。不幸的是,我不能自由选择从哪里读取属性,因为现在有另一个软件(GUI)不是我写的,它是一个写入数

Java 将参数约束到公共(public)父类(super class)

动机我有一个Either类,表示两种类型之一的值,或语义不同的状态。在某些情况下,无论值是哪个备选方案,对其进行操作都是有值(value)的。问题我想要一个采用Consumer的(非静态)方法,其中T是L的父类(superclass)型和R,其中L和R是类的类型参数。目前,java让我这样做:(静态实现)publicstaticvoidcollapse(Eithere,Consumerop)当然,对于非静态实现,我不能对L施加约束。和R,因为它们已经为相关实例定义。我需要对T施加的那些约束相反,但java不允许我编写以下内容,因为它一次只允许父类(superclass)型或子类型约束中

java - 使用 spring-ldap 1.3.1 禁用 Active Directory 服务器的 SSL 证书验证

如果只需要配置一个AD服务器,我可以向ActiveDirectory进行身份验证。解决方案如下ActiveDirectoryauthenticationthroughsslasanonymoususer由我。现在,当负载均衡器后面运行多个AD时,我陷入困境。由于负载均衡器介于两者之间,我将仅获取主机名,AD的IP将根据可用性替换为负载均衡器后面的主机名。因此,我无法知道将使用哪个ActiveDirectory服务器来处理我的身份验证请求。所以,我将无法提前生成证书。此外,我无法获取我的客户端用于平衡负载的广告的IP(出于安全原因)。所以没有生成jssecacert的意义。我需要做的就是

java - createCriteria 在没有 Activity 事务的情况下无效(Struts 2.3.15、Spring 3.2.4、Hibernate 4.2.5 Final)

任何人/导师/大师都可以帮我解决这个问题吗?我被困了超过2天通过注释的Java代码我在中收到此错误createCriteriaisnotvalidwithoutactivetransactionStruts2.3.15&Spring3.2.4&Hibernate4.2.5Final请查看详细错误信息如下:StrutsProblemReportStrutshasdetectedanunhandedexception:Messages:createCriteriaisnotvalidwithoutactivetransactionFile:org/hibernate/context/int

java - 如何(全局)替换Java并行流的公共(public)线程池后端?

我想全局替换Java并行流默认使用的公共(public)线程池,例如,IntStream.range(0,100).parallel().forEach(i->{doWork();});我知道可以通过将此类指令提交到专用线程池来使用专用ForkJoinPool(请参阅CustomthreadpoolinJava8parallelstream)。这里的问题是是否可以用一些其他实现(例如Executors.newFixedThreadPool(10))替换常见的ForkJoinPool?是否可以通过某些全局设置(例如某些JVM属性)来实现?备注:我之所以喜欢替换F/Jpool,是因为它似乎