小编Pet*_*nis的帖子

在多个jvm实例中运行java代码

我有一个Windows服务应用程序和一个使用RMI与服务进行通信的客户端.我需要对多个客户端进行一些并发测试,但我需要每个客户端运行到不同的jvm实例,因为它的代码中有一些静态变量.我能这样做吗?有任何想法吗?

java testing concurrency jvm

4
推荐指数
1
解决办法
1559
查看次数

Java中的枚举和多态,扑克牌示例

我尝试设计一个关于扑克牌的项目.我有一张卡片

class Card 
{
     Rank rank; 
     Suit suit;
}
Run Code Online (Sandbox Code Playgroud)

西装是一个枚举.

  enum Suit { .... }
Run Code Online (Sandbox Code Playgroud)

Rank应该有一个方法getValue().我希望有一个以上的排名,即.BlackJackRank和PokerRank.所以我创建了一个接口Rank,方法是getValue,两个枚举BlackJackRank和PokerRank实现了这个接口.

enum BlackJackRank implements Rank
{
   ACE(1),DEUCE(2),THREE(3) ....
   private final int value;
   private BackJackRank(int value) { ... }

   @Override
   public int getValue() { ... }
}
Run Code Online (Sandbox Code Playgroud)

我的问题是我不能在Card类中调用rank.name()和rank.ordinal(),因为Rank不是枚举.任何的想法?

java polymorphism enums interface

3
推荐指数
1
解决办法
4065
查看次数

当线程终止时,jvm是否释放线程的堆栈

我使用jvm参数在我的机器和客户机器上运行以下程序-Xmx1024m.

int i=0;
while(true)
{
  new Thread().start();
  i++;
}
Run Code Online (Sandbox Code Playgroud)

两台机器都有windows 7jdk 7 32bits.

在我的机器上,当我在3M附近时,我终止了这个过程.在客户的机器上,程序OutOfMemoryError: unable to create new native Thread在我大约8K 的时候扔了一个.

我用jvm参数重试了实验-Xmx24m.在这种情况下,当i大约24K时,客户机器上的程序会抛出相同的错误.如果我将线程的堆栈跟踪减少到128K,则还有一个小的增量-Xss.

看起来客户的机器在线程终止时不会释放线程的堆栈.

有没有人遇到过这个问题?有任何想法吗?

java multithreading garbage-collection exception out-of-memory

2
推荐指数
1
解决办法
368
查看次数

在Hive中将字符串转换为时间戳

我有一个值'2017-09-27T19:25:15.927-07:00',有什么办法可以将其转换为时间戳吗?我使用Hive 1.1.0。

select unix_timestamp("2017-09-27T19:25:15.927-07:00", "yyyy-MM-ddTHH:mm:ss.SSSX") 但它抛出 Bad date/time conversion format

select unix_timestamp("2017-09-27T19:25:15.927-07:00", "yyyy-MM-ddTHH:mm:ss.SSSZZZ") 但它返回 NULL

datetime hadoop hive timestamp-with-timezone impala

2
推荐指数
1
解决办法
6722
查看次数