You are viewing a plain text version of this content. The canonical link for it is here.
Posted to notifications@groovy.apache.org by "chenxiaojie (JIRA)" <ji...@apache.org> on 2018/06/21 09:14:00 UTC
[jira] [Issue Comment Deleted] (GROOVY-8653) foreach index value
error
[ https://issues.apache.org/jira/browse/GROOVY-8653?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
chenxiaojie updated GROOVY-8653:
--------------------------------
Comment: was deleted
(was: https://issues.apache.org/jira/browse/GROOVY-7409
the reason is similar to this issue.
my code is relatively simple, and it is not easy to find this problem.)
> foreach index value error
> -------------------------
>
> Key: GROOVY-8653
> URL: https://issues.apache.org/jira/browse/GROOVY-8653
> Project: Groovy
> Issue Type: Bug
> Components: Groovy Console, groovy-jdk
> Affects Versions: 2.3.7, 2.4.15
> Environment: jdk1.7.0_79
> Reporter: chenxiaojie
> Priority: Major
> Original Estimate: 12h
> Remaining Estimate: 12h
>
> {code:java}
> import java.util.concurrent.ConcurrentHashMap
> import java.util.concurrent.ExecutorService
> import java.util.concurrent.Executors
> import java.util.concurrent.TimeUnit
> import java.util.concurrent.atomic.AtomicInteger
>
> ConcurrentHashMap<Integer, AtomicInteger> map = new ConcurrentHashMap<Integer, AtomicInteger>(10000)
> ConcurrentHashMap<Integer, AtomicInteger> map2 = new ConcurrentHashMap<Integer, AtomicInteger>(10000)
> ConcurrentHashMap<Integer, AtomicInteger> map3 = new ConcurrentHashMap<Integer, AtomicInteger>(10000)
> ExecutorService es = Executors.newFixedThreadPool(100)
> 1.upto(10000) {
> i ->
> es.execute {
> AtomicInteger count = map.get(i)
> if (count == null) {
> count = new AtomicInteger(0)
> AtomicInteger oldCount = map.putIfAbsent(i, count)
> if (oldCount != null) {
> count = oldCount
> }
> }
> count.incrementAndGet()
> }
> }
> for (Integer i = 0; i < 10000; i++) {
> es.execute {
> AtomicInteger count = map2.get(i)
> if (count == null) {
> count = new AtomicInteger(0)
> AtomicInteger oldCount = map2.putIfAbsent(i, count)
> if (oldCount != null) {
> count = oldCount
> }
> }
> count.incrementAndGet()
> }
> }
> for (Integer i = 0; i < 10000; i++) {
> Integer j = i
> es.execute {
> AtomicInteger count = map3.get(j)
> if (count == null) {
> count = new AtomicInteger(0)
> AtomicInteger oldCount = map3.putIfAbsent(j, count)
> if (oldCount != null) {
> count = oldCount
> }
> }
> count.incrementAndGet()
> }
> }
> es.shutdown()
> es.awaitTermination(1, TimeUnit.MINUTES)
> // println 10000
> println map.size()
> // println 6583 ??? size is 0-10000 integer
> println map2.size()
> // println 10000
> println map3.size()
> {code}
--
This message was sent by Atlassian JIRA
(v7.6.3#76005)