Skip to content

Commit

Permalink
Fix inefficient forEach loop (#13742)
Browse files Browse the repository at this point in the history
### Motivation
There are some methods implemented with an inefficient forEach loop, so fix it to get better performance. It is similar to #12953

### Modifications

I rewrite it with the `for` loop.

(cherry picked from commit 9c94cd7)
  • Loading branch information
Shawyeok authored and codelipenghui committed Jan 18, 2022
1 parent 348ea61 commit 44b617b
Show file tree
Hide file tree
Showing 4 changed files with 30 additions and 23 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,6 @@
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentLinkedQueue;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.atomic.AtomicLongFieldUpdater;
import java.util.concurrent.atomic.LongAdder;
import java.util.concurrent.locks.ReentrantReadWriteLock;
Expand Down Expand Up @@ -264,14 +263,15 @@ public void enableCnxAutoRead() {
}

protected boolean hasLocalProducers() {
AtomicBoolean foundLocal = new AtomicBoolean(false);
producers.values().forEach(producer -> {
if (producers.isEmpty()) {
return false;
}
for (Producer producer : producers.values()) {
if (!producer.isRemote()) {
foundLocal.set(true);
return true;
}
});

return foundLocal.get();
}
return false;
}

@Override
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -596,14 +596,15 @@ public void updatePropertiesFailed(ManagedLedgerException exception, Object ctx)
}

private boolean hasRemoteProducers() {
AtomicBoolean foundRemote = new AtomicBoolean(false);
producers.values().forEach(producer -> {
if (producers.isEmpty()) {
return false;
}
for (Producer producer : producers.values()) {
if (producer.isRemote()) {
foundRemote.set(true);
return true;
}
});

return foundRemote.get();
}
return false;
}

public void startReplProducers() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -166,13 +166,15 @@ public String toString() {

@Override
public boolean isEmpty() {
AtomicBoolean isEmpty = new AtomicBoolean(true);
longPairSets.forEach((item1, longPairSet) -> {
if (isEmpty.get() && !longPairSet.isEmpty()) {
isEmpty.set(false);
if (longPairSets.isEmpty()) {
return true;
}
for (ConcurrentLongPairSet subSet : longPairSets.values()) {
if (!subSet.isEmpty()) {
return false;
}
});
return isEmpty.get();
}
return true;
}

@Override
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,21 +22,18 @@
import static org.testng.Assert.assertFalse;
import static org.testng.Assert.assertNotEquals;
import static org.testng.Assert.assertTrue;

import com.google.common.collect.Lists;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import java.util.Set;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

import lombok.Cleanup;
import org.apache.pulsar.common.util.collections.ConcurrentLongPairSet.LongPair;
import org.testng.annotations.Test;

import com.google.common.collect.Lists;

public class ConcurrentSortedLongPairSetTest {

@Test
Expand Down Expand Up @@ -241,4 +238,11 @@ public void testToString() {
assertEquals(set.toString(), toString);
}

@Test
public void testIsEmpty() {
LongPairSet set = new ConcurrentSortedLongPairSet();
assertTrue(set.isEmpty());
set.add(1, 1);
assertFalse(set.isEmpty());
}
}

0 comments on commit 44b617b

Please sign in to comment.