我有一个Windows服务应用程序和一个使用RMI与服务进行通信的客户端.我需要对多个客户端进行一些并发测试,但我需要每个客户端运行到不同的jvm实例,因为它的代码中有一些静态变量.我能这样做吗?有任何想法吗?
我尝试设计一个关于扑克牌的项目.我有一张卡片
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不是枚举.任何的想法?
我使用jvm参数在我的机器和客户机器上运行以下程序-Xmx1024m.
int i=0;
while(true)
{
new Thread().start();
i++;
}
Run Code Online (Sandbox Code Playgroud)
两台机器都有windows 7和jdk 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
我有一个值'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