Browsed by
标签:JAVA

好烂啊有点差凑合看看还不错很精彩 (No Ratings Yet)
Loading...
78 views
Maven 的依赖排查的几个命令

Maven 的依赖排查的几个命令

maven 的依赖排查的几个命令:

– mvn dependency:tree
说明:打印输出 Maven项目的所有依赖的POM中定义的jar
查看【输出示例1】

– mvn dependency:tree -Dverbose > d:/tmp/mvn-dependency-tree-verbose.out.txt
说明: 打印输出Maven项目的所有依赖的POM jar,但是增加verbose的参数,含有更多详细输出。
查看【输出示例2】

– mvn dependency:tree -Dverbose -Dincludes=org.slf4j > d:/tmp/mvn-dependency-tree-verbose-includes.out.txt
说明: 打印输出依赖POM jar, 但是有过滤性的输出。
查看【输出示例3】

 

参考一篇博客,通过 #mvn dependency:tree解决 java project中jar包冲突的问题:

Maven类包冲突终极三大解决技巧 mvn dependency:tree (https://blog.csdn.net/sun_wangdong/article/details/51852113)

 

【输出示例1】
[INFO] +- com.stormzhange.risky.rcomss.common.facade:risky-rcomss-common-facade:jar:2.2.1-20180426-SNAPSHOT:compile
[INFO] | \- com.stormzhange.risky.rcfs:risky-rcfs-api:jar:1.0.1-SNAPSHOT:compile
[INFO] | +- com.stormzhange.risky.common:risky-sharding:jar:1.4.0-SNAPSHOT:compile
[INFO] | | +- org.xerial.snappy:snappy- java:jar:1.1.2.4:compile
[INFO] | | \- com.alibaba:dubbo:jar:2.5.5:compile
[INFO] | | +- org. javassist: javassist:jar:3.20.0-GA:compile
[INFO] | | \- org.jboss.netty:netty:jar:3.2.5.Final:compile
[INFO] | +- com.stormzhange.risky.rcfs.common.facade:risky-rcfs-common-facade:jar:1.0.2-20170216-SNAPSHOT:compile
[INFO] | +- redis.clients:jedis:jar:2.9.0:compile
[INFO] | | \- org.apache.commons:commons-pool2:jar:2.4.2:compile
[INFO] | +- org.springframework.data:spring-data-redis:jar:1.8.9.RELEASE:compile
[INFO] | | +- org.springframework.data:spring-data-keyvalue:jar:1.2.9.RELEASE:compile
[INFO] | | | \- org.springframework.data:spring-data-commons:jar:1.13.9.RELEASE:compile
[INFO] | | \- org.springframework:spring-oxm:jar:4.3.13.RELEASE:compile
[INFO] | +- org.apache.commons:commons-lang3:jar:3.1:compile
[INFO] | +- org.apache.commons:commons-collections4:jar:4.1:compile
[INFO] | \- javax.inject: javax.inject:jar:1:compile
[INFO] +- org.apache.poi:poi:jar:3.9:compile
[INFO] | \- commons-codec:commons-codec:jar:1.5:compile
[INFO] \- org.apache.poi:poi-ooxml:jar:3.9:compile
[INFO] +- org.apache.poi:poi-ooxml-schemas:jar:3.9:compile
[INFO] | \- org.apache.xmlbeans:xmlbeans:jar:2.3.0:compile
[INFO] | \- stax:stax-api:jar:1.0.1:compile
[INFO] \- dom4j:dom4j:jar:1.6.1:compile
[INFO] \- xml-apis:xml-apis:jar:1.0.b2:compile

【输出示例2】
[INFO] +- com.google.guava:guava:jar:16.0:compile
[INFO] \- com.stormzhange.risky.rcfs:risky-rcfs-api:jar:1.0.1-SNAPSHOT:compile
[INFO] +- com.stormzhange.risky.common:risky-sharding:jar:1.4.0-SNAPSHOT:compile (version managed from 0.9.0-SNAPSHOT)
[INFO] | +- (com.stormzhange.common:common:jar:1.3.1:compile – omitted for duplicate)
[INFO] | +- (commons-lang:commons-lang:jar:2.6:compile – omitted for duplicate)
[INFO] | +- org.xerial.snappy:snappy- java:jar:1.1.2.4:compile
[INFO] | +- (org.springframework:spring-context:jar:4.3.3.RELEASE:compile – version managed from 3.2.3.RELEASE; omitted for duplicate)
[INFO] | +- (org.springframework:spring-core:jar:4.3.3.RELEASE:compile – omitted for duplicate)
[INFO] | +- org.springframework:spring-tx:jar:4.3.3.RELEASE:compile
[INFO] | | +- (org.springframework:spring-beans:jar:4.3.3.RELEASE:compile – omitted for duplicate)
[INFO] | | \- (org.springframework:spring-core:jar:4.3.3.RELEASE:compile – omitted for duplicate)
[INFO] | +- (org.springframework:spring-beans:jar:4.3.3.RELEASE:compile – omitted for duplicate)
[INFO] | +- (org.springframework.data:spring-data-redis:jar:1.8.9.RELEASE:compile – version managed from 1.6.2.RELEASE; omitted for duplicate)
[INFO] | +- (redis.clients:jedis:jar:2.9.0:compile – version managed from 2.7.0; omitted for duplicate)
[INFO] | +- (com.google.code.gson:gson:jar:2.2.4:compile – omitted for duplicate)
[INFO] | \- com.alibaba:dubbo:jar:2.5.5:compile (version managed from 2.5.3.4)
[INFO] | +- (org.springframework:spring-context:jar:4.3.3.RELEASE:compile – version managed from 4.3.10.RELEASE; omitted for duplicate)
[INFO] | +- (org.springframework:spring-beans:jar:4.3.3.RELEASE:compile – version managed from 4.3.10.RELEASE; omitted for duplicate)
[INFO] | +- org.springframework:spring-web:jar:4.3.3.RELEASE:compile (version managed from 4.3.10.RELEASE)
[INFO] | | +- (org.springframework:spring-aop:jar:4.3.3.RELEASE:compile – version managed from 4.3.13.RELEASE; omitted for duplicate)
[INFO] | | +- (org.springframework:spring-beans:jar:4.3.3.RELEASE:compile – version managed from 4.3.10.RELEASE; omitted for duplicate)
[INFO] | | +- (org.springframework:spring-context:jar:4.3.3.RELEASE:compile – version managed from 4.3.10.RELEASE; omitted for duplicate)
[INFO] | | \- (org.springframework:spring-core:jar:4.3.3.RELEASE:compile – version managed from 4.3.13.RELEASE; omitted for duplicate)
[INFO] | +- org. javassist: javassist:jar:3.20.0-GA:compile
[INFO] | \- org.jboss.netty:netty:jar:3.2.5.Final:compile
[INFO] +- com.stormzhange.risky.rcfs.common.facade:risky-rcfs-common-facade:jar:1.0.2-20170216-SNAPSHOT:compile (version managed from 1.0.2-20161117-SNAPSHOT)
[INFO] | +- (commons-lang:commons-lang:jar:2.6:compile – omitted for duplicate)
[INFO] | \- (com.stormzhange.risky.common:risky-common:jar:1.3.0-20171214-01:compile – version managed from 1.2.12-20160225.2; omitted for duplicate)
[INFO] +- redis.clients:jedis:jar:2.9.0:compile
[INFO] | \- org.apache.commons:commons-pool2:jar:2.4.2:compile
[INFO] +- org.springframework.data:spring-data-redis:jar:1.8.9.RELEASE:compile
[INFO] | +- org.springframework.data:spring-data-keyvalue:jar:1.2.9.RELEASE:compile
[INFO] | | +- org.springframework.data:spring-data-commons:jar:1.13.9.RELEASE:compile
[INFO] | | | +- (org.springframework:spring-core:jar:4.3.3.RELEASE:compile – version managed from 4.3.13.RELEASE; omitted for duplicate)
[INFO] | | | +- (org.springframework:spring-beans:jar:4.3.3.RELEASE:compile – version managed from 4.3.13.RELEASE; omitted for duplicate)
[INFO] | | | \- (org.slf4j:slf4j-api:jar:1.7.5:compile – version managed from 1.7.25; omitted for duplicate)
[INFO] | | +- (org.springframework:spring-context:jar:4.3.3.RELEASE:compile – version managed from 4.3.13.RELEASE; omitted for duplicate)
[INFO] | | +- (org.springframework:spring-tx:jar:4.3.3.RELEASE:compile – version managed from 4.3.13.RELEASE; omitted for duplicate)
[INFO] | | \- (org.slf4j:slf4j-api:jar:1.7.5:compile – version managed from 1.7.25; omitted for duplicate)
[INFO] | +- (org.springframework:spring-tx:jar:4.3.3.RELEASE:compile – version managed from 4.3.13.RELEASE; omitted for duplicate)
[INFO] | +- org.springframework:spring-oxm:jar:4.3.13.RELEASE:compile
[INFO] | | +- (org.springframework:spring-beans:jar:4.3.3.RELEASE:compile – version managed from 4.3.13.RELEASE; omitted for duplicate)
[INFO] | | \- (org.springframework:spring-core:jar:4.3.3.RELEASE:compile – version managed from 4.3.13.RELEASE; omitted for duplicate)
[INFO] | +- (org.springframework:spring-aop:jar:4.3.3.RELEASE:compile – version managed from 4.3.13.RELEASE; omitted for duplicate)
[INFO] | +- org.springframework:spring-context-support:jar:4.3.3.RELEASE:compile (version managed from 4.3.13.RELEASE)
[INFO] | | +- (org.springframework:spring-beans:jar:4.3.3.RELEASE:compile – version managed from 4.3.13.RELEASE; omitted for duplicate)
[INFO] | | +- (org.springframework:spring-context:jar:4.3.3.RELEASE:compile – version managed from 4.3.13.RELEASE; omitted for duplicate)
[INFO] | | \- (org.springframework:spring-core:jar:4.3.3.RELEASE:compile – version managed from 4.3.13.RELEASE; omitted for duplicate)
[INFO] | \- (org.slf4j:slf4j-api:jar:1.7.5:compile – version managed from 1.7.25; omitted for duplicate)
[INFO] +- org.apache.commons:commons-lang3:jar:3.1:compile
[INFO] +- org.apache.commons:commons-collections4:jar:4.1:compile
[INFO] +- (com.google.guava:guava:jar:16.0:compile – omitted for duplicate)
[INFO] \- javax.inject: javax.inject:jar:1:compile

【输出示例3】
[INFO]
[INFO] — maven-dependency-plugin:2.8:tree (default-cli) @ risky-rcomss-common-dal —
[INFO] com.stormzhange.risky.rcomss.common.dal:risky-rcomss-common-dal:jar:1.0
[INFO] \- com.stormzhange.risky.rcomss.common.util:risky-rcomss-common-util:jar:1.0:compile
[INFO] +- com.stormzhange.risky.common:risky-common:jar:1.3.0-20171214-01:compile
[INFO] | \- org.slf4j:slf4j-api:jar:1.7.5:compile
[INFO] +- ch.qos.logback:logback-classic:jar:1.0.13:compile
[INFO] | \- (org.slf4j:slf4j-api:jar:1.7.5:compile – omitted for duplicate)
[INFO] +- org.slf4j:jcl-over-slf4j:jar:1.7.5:compile
[INFO] | \- (org.slf4j:slf4j-api:jar:1.7.5:compile – omitted for duplicate)
[INFO] +- com.pingan.zues:zues-utility-logging:jar:1.2.8:compile
[INFO] | +- (org.slf4j:slf4j-api:jar:1.7.5:compile – omitted for duplicate)
[INFO] | +- (org.slf4j:jcl-over-slf4j:jar:1.7.5:compile – omitted for duplicate)
[INFO] | +- (org.slf4j:log4j-over-slf4j:jar:1.7.5:compile – omitted for duplicate)
[INFO] | \- com.pingan.zues:zues-utility-common:jar:1.2.1:compile
[INFO] | \- (org.slf4j:slf4j-api:jar:1.7.5:compile – omitted for duplicate)
[INFO] +- org.slf4j:log4j-over-slf4j:jar:1.7.5:compile
[INFO] | \- (org.slf4j:slf4j-api:jar:1.7.5:compile – omitted for duplicate)
[INFO] \- com.stormzhange.risky.rcomss.common.facade:risky-rcomss-common-facade:jar:2.2.1-20180426-SNAPSHOT:compile
[INFO] \- com.stormzhange.risky.rcfs:risky-rcfs-api:jar:1.0.1-SNAPSHOT:compile
[INFO] \- org.springframework.data:spring-data-redis:jar:1.8.9.RELEASE:compile
[INFO] +- org.springframework.data:spring-data-keyvalue:jar:1.2.9.RELEASE:compile
[INFO] | +- org.springframework.data:spring-data-commons:jar:1.13.9.RELEASE:compile
[INFO] | | \- (org.slf4j:slf4j-api:jar:1.7.5:compile – version managed from 1.7.25; omitted for duplicate)
[INFO] | \- (org.slf4j:slf4j-api:jar:1.7.5:compile – version managed from 1.7.25; omitted for duplicate)
[INFO] \- (org.slf4j:slf4j-api:jar:1.7.5:compile – version managed from 1.7.25; omitted for duplicate)
[INFO]

好烂啊有点差凑合看看还不错很精彩 (No Ratings Yet)
Loading...
180 views
使用ToStringBuilder.reflectionToString实现toString方法

使用ToStringBuilder.reflectionToString实现toString方法

org.apache.commons.lang.builder.ToStringBuilder.reflectionToString(Object, ToStringStyle)是commons-lang里的一个类。

实现一个类的toString方法是一件无聊的事情。
使用ToStringBuilder/ReflectionToStringBuilder可以让生活更美好一点。

@Override
public String toString() {
// return ReflectionToStringBuilder.toStringExclude(this, “fileBody”);
return ToStringBuilder.reflectionToString(this, ToStringStyle.SHORT_PREFIX_STYLE);
}

如果需要排除某些字段, 可以使用ReflectionToStringBuilder.toStringExclude方法。 (org.apache.commons.lang3.builder.ReflectionToStringBuilder.toStringExclude(Object, String…))

好烂啊有点差凑合看看还不错很精彩 (No Ratings Yet)
Loading...
227 views
THE CODE GEEKS NETWORK

THE CODE GEEKS NETWORK

好烂啊有点差凑合看看还不错很精彩 (No Ratings Yet)
Loading...
627 views
Java日期格式化

Java日期格式化

Java日期格式化

 

import java.text.ParseException;

import java.text.SimpleDateFormat;

import java.util.Date;

import java.util.Locale;

public class CX {

public static void main(String[] args) throws ParseException {

SimpleDateFormat sdf;

Date date; String s, s2 ;

// Jul 20, 2016 2:05:09 pm

String ds = “Jul 20, 2016 2:05:09 pm”;

date = new Date();

sdf = new SimpleDateFormat(“MMMMM dd,yyyy hh:mm:ss a”, Locale.ENGLISH );

s = sdf.format(date);

System.out.println(s);

date = sdf.parse(s);

System.out.println(“date = ” + date);

date = sdf.parse(ds);

System.out.println(“date2 = ” + date);

sdf = new SimpleDateFormat(“MMM dd,yyyy hh:mm:ss aa”, Locale.ENGLISH);

s = sdf.format(date); System.out.println(s);

date = sdf.parse(s);

System.out.println(“date = ” + date);

date = sdf.parse(ds);

System.out.println(“date2 = ” + date); }
}

输出:

June 22,2017 03:33:48 PM

date = Thu Jun 22 15:33:48 CST 2017

date2 = Wed Jul 20 14:05:09 CST 2016

Jul 20,2016 02:05:09 PM

date = Wed Jul 20 14:05:09 CST 2016

date2 = Wed Jul 20 14:05:09 CST 2016

好烂啊有点差凑合看看还不错很精彩 (No Ratings Yet)
Loading...
735 views
全栈技术构建web应用

全栈技术构建web应用

如何构建一个中型的 web 应用(全栈技术)

计算机界的轮子已经如此之多,我的观点是技术不转化成应用是没有价值的,本文主要挑选了一些技术,复用一些优秀的轮子,用最小的成本构建自己的 web 应用。

主要内容

界面设计

boostrap twitter 出品的响应式框架,可以快速构建优美的前端界面

material-design-lite Google 出品的Material Design 风格的前端框架

前端库 /框架

jquery 方便快捷地操纵 dom

前端构建工具

yog2 百度出品的前端构建工具,将fis3express结合在一起

webpack 当下最火的前端构建工具

后端语言

nodejavascript 写后端应用

后端框架

express node.js 官方推荐的 web 框架

koa express 原始团队出品,口碑很好,我并没有在实际项目中使用过

数据库

mysql 全球最流行的开源数据库,各大互联网公司都在大范围使用

mongo 时下最流行的 nosql 数据库,经过几年的发展已经很稳定了

数据库驱动

knex mysql 的 node.js 版的 sql 构建库,需要搭配mysql 的 node.js 驱动 使用

mongoose mongo 的 node.js 版的数据库驱动

代码部署

ansible 基于 ssh 的自动化部署工具,我还在摸索的阶段

云主机

ucloud 口碑不错的云服务商

阿里云 阿里巴巴旗下的云服务,号称国内最大

百度云 推荐一下自家公司的产品

CDN

七牛云 老牌云存储服务商,有免费额度

原文地址: https://github.com/Arnoldnuo/how-to-make-web-app

 

好烂啊有点差凑合看看还不错很精彩 (No Ratings Yet)
Loading...
641 views
让大家在InfoQ上听见你的声音

让大家在InfoQ上听见你的声音

投稿

InfoQ由社区推动,这里的内容源自像你一样的专业技术人。对于社区而言,你是最重要的。

你是否热衷于软件开发?你是否热衷于与他人分享你的知识与经验?InfoQ一直在寻找优秀的作者与热情的编辑加入我们的内容贡献队伍中,跟社区里的其他成员一起,促进软件开发领域知识与创新的传播。

为InfoQ贡献内容的方式有两种,联系方式均为editors@cn.infoq.com:

深度文章投稿

深度文章不是简单的How-to。
作者需要对某个领域有十分深入的理解,
或非常丰富的实战经验。
详情见InfoQ中文站投稿须知

成为社区编辑

InfoQ社区编辑能够在自己关注的领域挖掘热点新闻和人物,并直观的将事实表述出来分享给读者。社区编辑分为翻译组、原创新闻组、专家审校组等,详见:
InfoQ编辑团队加盟指南

InfoQ编辑的核心价值观

InfoQ.com是由实践者驱动的社区媒体,我们的目标是: 推进和传播软件开发领域的知识和创新。 作为编辑兼实践者,我们参与成员驱动的编辑过程,向着这个共同目标努力前进,具体工作方式包括:翻译和撰写新闻,并以文章、采访、录制技术大会视频等多种形式分享知识。

我们恪守并践行下列核心价值观:

做信息的罗宾汉。我们的主要职能就是从少数拥有信息的精英那里寻找信息,并将其发布给广大群众。当我们发现一些很棒的信息,并且认为值得让整个社区知道时,我们应该将发布它视为我们必须承担的职责。

做最好的,而不是最快的。我们不是发布突发新闻的网站,当某件事情发生后,过上几天再发布也是可以的,只要我们收集到足够的材料,并能提供更深度的内容。

做推进者,而不是领导者。我们会编写各种内容,展现社区中的新人老将、各种活动、各种想法,以此推进社区的成长,而不是关注我们自己。作为推进者,我们与社区协作,产生有价值的内容,而不是只考虑推行我们的想法;我们能够而且应该辅助现有的各种业界活动和趋势。

提供可信赖的内容。我们的内容将会不带偏见,不会偏向个人或是厂商,除非能够明确表明属于某种“意见”。用户可以期望InfoQ的内容有所裨益,而且源于事实。我们努力坚持媒体工作的原则,并体现在我们的新闻写作活动中,同时也要认识到:我们不是全职的权威媒体工作者,而是试图做正确之事的实践者。

来源: 让大家在InfoQ上听见你的声音

好烂啊有点差凑合看看还不错很精彩 (No Ratings Yet)
Loading...
523 views
Is Java “pass-by-reference” or “pass-by-value”?

Is Java “pass-by-reference” or “pass-by-value”?

结果让人有些意外,到底是 引用传递 还是 值传递?

public class DogTest {

public static void main( String[] args ) {
Dog aDog = new Dog(“Max”);
// we pass the object to foo
foo(aDog);
// aDog variable is still pointing to the “Max” dog when foo(…) returns
if (aDog.getName().equals(“Max”)) { System.out.println(“11=”+aDog);} // true, java passes by value
if (aDog.getName().equals(“Fifi”)) { System.out.println(“22=”+aDog);} // false
}

public static void foo(Dog d) {
d.getName().equals(“Max”); // true
// change d inside of foo() to point to a new Dog instance “Fifi”
d = new Dog(“Fifi”);
if (d.getName().equals(“Fifi”)) { System.out.println(“33=”+d); } // true
}
}

class Dog {
String name;
public Dog(String s ){
name =s ;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}

@Override
public String toString() {
// TODO Auto-generated method stub
return String.format(” Dog[name=%s]”, name);
}
}

来源: methods – Is Java “pass-by-reference” or “pass-by-value”? – Stack Overflow

好烂啊有点差凑合看看还不错很精彩 (No Ratings Yet)
Loading...
733 views
redis tech issue & solution in production

redis tech issue & solution in production

最近碰到产线问题,记录一下发现原因、解决办法、问题思考。

问题表现

  1. redis交换区
  2. redis内存占用过大无法备份

分析定位

redis单机server运行,主备模式;但是备机出现无法备份成功,error日志频出。

机器配置内存32G,当前已使用26G。

bgsave运行失败。

解决办法

Sharding算法引入,进行分布式管理;

解决 1- redis单机模式;2-redis水平扩展性。

 

-end-

好烂啊有点差凑合看看还不错很精彩 (No Ratings Yet)
Loading...
1,065 views
Java Code with Highlight

Java Code with Highlight

from:

http://math.hws.edu/eck/cs124/ javanotes3/source/Interest1Console. java

show the code :


/* Simulation of console-I/O program Interest1,
   using Console Applet as a basis.  See the file
   Console Applet. java for more information.
   
   David Eck
   eck@hws.edu
   
*/

public class Interest1Console extends Console Applet {

   protected String getTitle() {
      return "Sample program \"Interest1\"";
   }

   protected void program() {

      /*
        Program  computes the amount of interest that is
        earned on $17,000 invested at an interest
        rate of 0.07 for one year.  The interest and
        the value of the investment after one year are
        printed to standard output.
     */


      double principal;     // The value of the investment.
      double rate;          // The annual interest rate.
      double interest;      // Interest earned in one year.
    
      /* Do the computations. */
    
      principal = 17000;
      rate = 0.07;
      interest = principal * rate;   // Compute the interest.
    
      principal = principal + interest;
      // Compute value of investment after one year, with interest.
      // (Note: The new value replaces the old value of principal.)
          
      /* Output the results. */
            
      console.put("The interest earned is $");
      console.putln(interest);
      console.put("The value of the investment after one year is $");
      console.putln(principal);

   }
}

 Java代码2:


public class DateUtil {

 /**
 * 只比较日期,不比较小时,分钟,秒
 * @param date1
 * @param date2
 * @return date1  date2 返回 1
 */
 public static int compareOnlyDate(Date date1, Date date2) {
 Calendar cal1 = Calendar.getInstance();
 cal1.setTime(date1);
 cal1.set(Calendar.HOUR_OF_DAY, 0);
 cal1.set(Calendar.MINUTE, 0);
 cal1.set(Calendar.SECOND, 0);
 cal1.set(Calendar.MILLISECOND, 0);
 Calendar cal2 = Calendar.getInstance();
 cal2.setTime(date2);
 cal2.set(Calendar.HOUR_OF_DAY, 0);
 cal2.set(Calendar.MINUTE, 0);
 cal2.set(Calendar.SECOND, 0);
 cal2.set(Calendar.MILLISECOND, 0);
 return cal1.compareTo(cal2);
 }
 
}
好烂啊有点差凑合看看还不错很精彩 (No Ratings Yet)
Loading...
720 views
疫苗:Java HashMap的死循环 | | 酷 壳 – CoolShell

疫苗:Java HashMap的死循环 | | 酷 壳 – CoolShell

在淘宝内网里看到同事发了贴说了一个CPU被100%的线上故障,并且这个事发生了很多次,原因是在 Java语言在并发情况下使用HashMap造成Race Condition,从而导致死循环。这个事情我4、5年前也经历过,本来觉得没什么好写的,因为 Java的HashMap是非线程安全的,所以在并发下必然出现问题。但是,我发现近几年,很多人都经历过这个事(在网上查“HashMap Infinite Loop”可以看到很多人都在说这个事)所以,觉得这个是个普遍问题,需要写篇疫苗文章说一下这个事,并且给大家看看一个完美的“Race Condition”是怎么形成的。 问题的症状 从前我们的 Java代码因为一些原因使用了HashMap这个东西,但是当时的程序是单线程的,一切都没有问题。后来,我们的程序性能有问题,所以需要变成多线程的,于是,变成多线程后到了线上,发现程序经常占了100%的CPU,查看堆栈,你会发现程序都Hang在了HashMap.get()这个方法上了,重启程序后问题消失。但是过段时间又会来。而且,这个问题在测试环境里可能很难重现。 我们简单的看一下我们自己的代码,我们就知道HashMap被多个线程操作。而 Java的文档说HashMap是非线程安全的,应该用ConcurrentHashMap。 但是在这里我们可以来研究一下原因。 Hash表数据结构 我需要简单地说一下HashMap这个经典的数据结构。 HashMap通常会用一个指针数组(假设为table中,如果有两个不同的key被算在了同一个i,那么就叫冲突,又叫碰撞,这样会在table上形成一个链表。 我们知道,如果tablepublic V put(K key, V value) { …… //算Hash值 int hash = hash(key.hashCode()); int i = indexFor(hash, table.length); //如果该key已被插入,则替换掉旧的value (链接操作) for (Entry e = table; e != null; e = e.next) { Object k; if (e.hash == hash && ((k = e.key) == key || key.equals(k))) { V

来源: 疫苗: Java HashMap的死循环 | | 酷 壳 – CoolShell

跳至工具栏