From 119bcbfc26b267fec569c5958fce9d0aaab972f5 Mon Sep 17 00:00:00 2001 From: Peter Lawrey Date: Mon, 23 Oct 2023 16:29:41 +0100 Subject: [PATCH 1/9] Remove internalNumberBuffer --- pom.xml | 6 ++++++ .../map/impl/stage/data/ZeroBytesStore.java | 5 +++++ .../chronicle/map/CHMUseCasesTest.java | 21 ++++++++++++++++--- 3 files changed, 29 insertions(+), 3 deletions(-) diff --git a/pom.xml b/pom.xml index 3f99a561aa..5472221dbd 100644 --- a/pom.xml +++ b/pom.xml @@ -69,6 +69,12 @@ chronicle-core + + net.openhft + chronicle-bytes + 2.24ea19 + + net.openhft posix diff --git a/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java b/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java index a48a13c6c0..875f92f3ed 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java +++ b/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java @@ -158,6 +158,11 @@ public boolean compareAndSwapLong(long offset, long expected, long value) { return true; } + @Deprecated(/* to be removed in x.25 */) + public byte[] internalNumberBuffer() { + throw new UnsupportedOperationException(); + } + @Override public byte[] internalNumberBuffer() { throw new UnsupportedOperationException(); diff --git a/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java b/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java index b3cb6d0cb5..99446e5a78 100644 --- a/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java +++ b/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java @@ -1108,17 +1108,17 @@ public ByteBuffer apply(ByteBuffer s) { }; map.put(key1, value1); - assertBBEquals(ByteBuffer.wrap(new byte[]{11, 11}), map.getMapped(key1, function)); + assertBBEquals(wrapAsByteBuffer(new byte[]{11, 11}), map.getMapped(key1, function)); assertEquals(null, map.getMapped(key2, function)); mapChecks(); - assertBBEquals(ByteBuffer.wrap(new byte[]{12, 10}), + assertBBEquals(wrapAsByteBuffer(new byte[]{12, 10}), map.computeIfPresent(key1, (k, s) -> { s.put(0, (byte) (s.get(0) + 1)); s.put(1, (byte) (s.get(1) - 1)); return function.apply(s); })); - assertBBEquals(ByteBuffer.wrap(new byte[]{12, 10}), map.get(key1)); + assertBBEquals(wrapAsByteBuffer(new byte[]{12, 10}), map.get(key1)); mapChecks(); @@ -1185,6 +1185,21 @@ public ByteBuffer apply(ByteBuffer s) { } } + @NotNull + private static ByteBuffer newDIrectByteBufferOf(int capacity1) { + return ByteBuffer.allocateDirect(capacity1).order(ByteOrder.nativeOrder()); + } + + @NotNull + private static ByteBuffer newByteBufferOf(int capacity) { + return ByteBuffer.allocate(capacity).order(ByteOrder.nativeOrder()); + } + + @NotNull + private static ByteBuffer wrapAsByteBuffer(byte[] array) { + return ByteBuffer.wrap(array).order(ByteOrder.nativeOrder()); + } + @Test public void testByteBufferDirectByteBufferMap() throws IOException { From cc665d24cca0001d1115cb93885cc70ac1e6752a Mon Sep 17 00:00:00 2001 From: Peter Lawrey Date: Mon, 23 Oct 2023 16:39:40 +0100 Subject: [PATCH 2/9] Remove internalNumberBuffer --- .../chronicle/map/CHMUseCasesTest.java | 26 ++++--------------- 1 file changed, 5 insertions(+), 21 deletions(-) diff --git a/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java b/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java index 99446e5a78..f32cdb7797 100644 --- a/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java +++ b/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java @@ -44,7 +44,6 @@ import java.io.IOException; import java.io.Serializable; import java.nio.ByteBuffer; -import java.nio.ByteOrder; import java.util.*; import java.util.function.BiFunction; @@ -1108,17 +1107,17 @@ public ByteBuffer apply(ByteBuffer s) { }; map.put(key1, value1); - assertBBEquals(wrapAsByteBuffer(new byte[]{11, 11}), map.getMapped(key1, function)); + assertBBEquals(ByteBuffer.wrap(new byte[]{11, 11}), map.getMapped(key1, function)); assertEquals(null, map.getMapped(key2, function)); mapChecks(); - assertBBEquals(wrapAsByteBuffer(new byte[]{12, 10}), + assertBBEquals(ByteBuffer.wrap(new byte[]{12, 10}), map.computeIfPresent(key1, (k, s) -> { s.put(0, (byte) (s.get(0) + 1)); s.put(1, (byte) (s.get(1) - 1)); return function.apply(s); })); - assertBBEquals(wrapAsByteBuffer(new byte[]{12, 10}), map.get(key1)); + assertBBEquals(ByteBuffer.wrap(new byte[]{12, 10}), map.get(key1)); mapChecks(); @@ -1174,7 +1173,7 @@ public ByteBuffer apply(ByteBuffer s) { MapEntry entry = c.entry(); assertNotNull(entry); - ByteBuffer bb1 = ByteBuffer.allocate(8).order(ByteOrder.nativeOrder()); + ByteBuffer bb1 = ByteBuffer.allocate(8); bb1.put(value1); bb1.putShort((short) 12345); bb1.flip(); @@ -1185,21 +1184,6 @@ public ByteBuffer apply(ByteBuffer s) { } } - @NotNull - private static ByteBuffer newDIrectByteBufferOf(int capacity1) { - return ByteBuffer.allocateDirect(capacity1).order(ByteOrder.nativeOrder()); - } - - @NotNull - private static ByteBuffer newByteBufferOf(int capacity) { - return ByteBuffer.allocate(capacity).order(ByteOrder.nativeOrder()); - } - - @NotNull - private static ByteBuffer wrapAsByteBuffer(byte[] array) { - return ByteBuffer.wrap(array).order(ByteOrder.nativeOrder()); - } - @Test public void testByteBufferDirectByteBufferMap() throws IOException { @@ -1222,7 +1206,7 @@ public void testByteBufferDirectByteBufferMap() .asReadOnlyBuffer(); final ByteBuffer key2 = ByteBuffer.wrap(new byte[]{2, 2, 2, 2}); - // Apparently, asReadOnlyBuffer cannot be used as keys because the backing array cannot be exposed; + // Apparently, asReadOnlyBuffer cannot be used as keys because the backing array cannot be exposed; final ByteBuffer value1 = ((ByteBuffer) ByteBuffer.allocateDirect(4) .put(new byte[]{11, 11, 11, 11}) From 55cb451aad0c84371677669c48675880e0583598 Mon Sep 17 00:00:00 2001 From: Peter Lawrey Date: Mon, 23 Oct 2023 16:41:35 +0100 Subject: [PATCH 3/9] Remove internalNumberBuffer --- src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java | 1 + 1 file changed, 1 insertion(+) diff --git a/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java b/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java index f32cdb7797..6c6657b750 100644 --- a/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java +++ b/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java @@ -44,6 +44,7 @@ import java.io.IOException; import java.io.Serializable; import java.nio.ByteBuffer; +import java.nio.ByteOrder; import java.util.*; import java.util.function.BiFunction; From 3a7e3fa524b2e9635e8e2d05822d7c970d5017a4 Mon Sep 17 00:00:00 2001 From: "yevgen.pavlenko" Date: Tue, 24 Oct 2023 13:00:48 +0300 Subject: [PATCH 4/9] Bring override back. --- .../openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java | 1 + 1 file changed, 1 insertion(+) diff --git a/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java b/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java index 875f92f3ed..d94538ebd7 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java +++ b/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java @@ -159,6 +159,7 @@ public boolean compareAndSwapLong(long offset, long expected, long value) { } @Deprecated(/* to be removed in x.25 */) + @Override public byte[] internalNumberBuffer() { throw new UnsupportedOperationException(); } From 12ec38144f56c9b436a64a305cabcd0f72f1ce92 Mon Sep 17 00:00:00 2001 From: "yevgen.pavlenko" Date: Mon, 23 Oct 2023 18:29:41 +0300 Subject: [PATCH 5/9] Remove deprecated code. --- pom.xml | 6 -- .../hash/impl/VanillaChronicleHash.java | 5 +- .../stage/data/bytes/InputKeyBytesData.java | 4 +- .../impl/util/CanonicalRandomAccessFiles.java | 2 +- .../impl/BytesMarshallableDataAccess.java | 2 +- .../impl/SizedMarshallableDataAccess.java | 2 +- .../map/impl/CompiledMapIterationContext.java | 83 ++++++------------- .../map/impl/CompiledMapQueryContext.java | 12 +-- ...CompiledReplicatedMapIterationContext.java | 6 +- .../CompiledReplicatedMapQueryContext.java | 12 +-- .../map/impl/stage/data/ZeroBytesStore.java | 16 ---- .../data/bytes/WrappedValueBytesData.java | 4 +- .../chronicle/map/CHMUseCasesTest.java | 2 +- .../chronicle/map/MemoryLeaksTest.java | 2 +- .../map/channel/PerfMapHandlerMain.java | 2 +- .../chronicle/map/ipc/StateMachineData.java | 13 +++ .../net/openhft/lang/values/DoubleArray.java | 13 +++ 17 files changed, 77 insertions(+), 109 deletions(-) diff --git a/pom.xml b/pom.xml index 5472221dbd..3f99a561aa 100644 --- a/pom.xml +++ b/pom.xml @@ -69,12 +69,6 @@ chronicle-core - - net.openhft - chronicle-bytes - 2.24ea19 - - net.openhft posix diff --git a/src/main/java/net/openhft/chronicle/hash/impl/VanillaChronicleHash.java b/src/main/java/net/openhft/chronicle/hash/impl/VanillaChronicleHash.java index b56d542cbd..462917c437 100644 --- a/src/main/java/net/openhft/chronicle/hash/impl/VanillaChronicleHash.java +++ b/src/main/java/net/openhft/chronicle/hash/impl/VanillaChronicleHash.java @@ -224,8 +224,6 @@ public VanillaChronicleHash(@NotNull final ChronicleMapBuilder builder) { preShutdownAction = privateAPI.getPreShutdownAction(); skipCloseOnExitHook = privateAPI.skipCloseOnExitHook(); - - disableThreadSafetyCheck(true); } public static IOException throwRecoveryOrReturnIOException(@NotNull final File file, @@ -934,8 +932,7 @@ private void allocateTierBulk() { globalMutableState.addDataStoreSize(tierBulkSizeInBytes); } - // TODO: x.25 remove throws IOException - public void msync() throws IOException { + public void msync() { throwExceptionIfClosed(); if (persisted()) { diff --git a/src/main/java/net/openhft/chronicle/hash/impl/stage/data/bytes/InputKeyBytesData.java b/src/main/java/net/openhft/chronicle/hash/impl/stage/data/bytes/InputKeyBytesData.java index 6fdb3b4a47..e7690eaeb4 100644 --- a/src/main/java/net/openhft/chronicle/hash/impl/stage/data/bytes/InputKeyBytesData.java +++ b/src/main/java/net/openhft/chronicle/hash/impl/stage/data/bytes/InputKeyBytesData.java @@ -26,8 +26,6 @@ import net.openhft.sg.StageRef; import net.openhft.sg.Staged; -import static net.openhft.chronicle.bytes.NoBytesStore.NO_BYTES_STORE; - @Staged public class InputKeyBytesData extends AbstractData { @@ -66,7 +64,7 @@ void initInputKeyBytes() { } void closeInputKeyBytes() { - inputKeyBytes.bytesStore(NO_BYTES_STORE, 0, 0); + inputKeyBytes.bytesStore(BytesStore.empty(), 0, 0); inputKeyBytesUsed = false; } diff --git a/src/main/java/net/openhft/chronicle/hash/impl/util/CanonicalRandomAccessFiles.java b/src/main/java/net/openhft/chronicle/hash/impl/util/CanonicalRandomAccessFiles.java index 3e0a31d37d..87efc65c57 100644 --- a/src/main/java/net/openhft/chronicle/hash/impl/util/CanonicalRandomAccessFiles.java +++ b/src/main/java/net/openhft/chronicle/hash/impl/util/CanonicalRandomAccessFiles.java @@ -16,9 +16,9 @@ package net.openhft.chronicle.hash.impl.util; -import net.openhft.chronicle.core.CleaningRandomAccessFile; import net.openhft.chronicle.core.Jvm; import net.openhft.chronicle.core.OS; +import net.openhft.chronicle.core.io.CleaningRandomAccessFile; import net.openhft.chronicle.hash.ChronicleFileLockException; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; diff --git a/src/main/java/net/openhft/chronicle/hash/serialization/impl/BytesMarshallableDataAccess.java b/src/main/java/net/openhft/chronicle/hash/serialization/impl/BytesMarshallableDataAccess.java index ee2d024526..7f0b30aed8 100644 --- a/src/main/java/net/openhft/chronicle/hash/serialization/impl/BytesMarshallableDataAccess.java +++ b/src/main/java/net/openhft/chronicle/hash/serialization/impl/BytesMarshallableDataAccess.java @@ -94,7 +94,7 @@ public void writeTo(RandomDataOutput target, long targetOffset) { target.capacity() - targetOffset); targetBytes.writePosition(targetOffset); instance.writeMarshallable(targetBytes); - targetBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + targetBytes.bytesStore(BytesStore.empty(), 0, 0); } } diff --git a/src/main/java/net/openhft/chronicle/hash/serialization/impl/SizedMarshallableDataAccess.java b/src/main/java/net/openhft/chronicle/hash/serialization/impl/SizedMarshallableDataAccess.java index 57b790df36..765ef381c0 100644 --- a/src/main/java/net/openhft/chronicle/hash/serialization/impl/SizedMarshallableDataAccess.java +++ b/src/main/java/net/openhft/chronicle/hash/serialization/impl/SizedMarshallableDataAccess.java @@ -104,7 +104,7 @@ public void writeTo(RandomDataOutput target, long targetOffset) { targetBytes.bytesStore((BytesStore) target, targetOffset, size); targetBytes.writePosition(targetOffset); sizedWriter.write(targetBytes, size, instance); - targetBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + targetBytes.bytesStore(BytesStore.empty(), 0, 0); } } diff --git a/src/main/java/net/openhft/chronicle/map/impl/CompiledMapIterationContext.java b/src/main/java/net/openhft/chronicle/map/impl/CompiledMapIterationContext.java index 871956cb0d..80639fa492 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/CompiledMapIterationContext.java +++ b/src/main/java/net/openhft/chronicle/map/impl/CompiledMapIterationContext.java @@ -1,64 +1,35 @@ package net.openhft.chronicle.map.impl; -import net.openhft.chronicle.hash.AbstractData; -import net.openhft.chronicle.algo.bytes.Access; -import net.openhft.chronicle.hash.impl.stage.entry.Alloc; -import java.util.ArrayList; -import java.util.function.BiFunction; -import net.openhft.chronicle.hash.impl.BigSegmentHeader; +import net.openhft.chronicle.algo.MemoryUnit; import net.openhft.chronicle.algo.bitset.BitSetFrame; -import net.openhft.chronicle.bytes.Bytes; -import net.openhft.chronicle.bytes.BytesStore; -import net.openhft.chronicle.bytes.BytesUtil; -import net.openhft.chronicle.hash.impl.stage.hash.ChainingInterface; -import net.openhft.chronicle.hash.ChecksumEntry; -import net.openhft.chronicle.hash.impl.stage.entry.ChecksumStrategy; -import net.openhft.chronicle.hash.ChronicleHash; -import net.openhft.chronicle.hash.ChronicleHashCorruption; -import net.openhft.chronicle.map.ChronicleHashCorruptionImpl; -import net.openhft.chronicle.hash.ChronicleHashRecoveryFailedException; -import net.openhft.chronicle.map.ChronicleMap; -import net.openhft.chronicle.set.ChronicleSet; -import net.openhft.chronicle.hash.impl.CompactOffHeapLinearHashTable; -import java.util.ConcurrentModificationException; -import java.util.function.Consumer; -import net.openhft.chronicle.hash.Data; -import net.openhft.chronicle.hash.serialization.DataAccess; -import net.openhft.chronicle.map.ExternalMapQueryContext; -import net.openhft.chronicle.hash.HashEntry; -import net.openhft.chronicle.hash.HashSegmentContext; +import net.openhft.chronicle.algo.bitset.ReusableBitSet; +import net.openhft.chronicle.algo.bitset.SingleThreadedFlatBitSetFrame; +import net.openhft.chronicle.algo.bytes.Access; +import net.openhft.chronicle.algo.hashing.LongHashFunction; +import net.openhft.chronicle.bytes.*; +import net.openhft.chronicle.core.Jvm; import net.openhft.chronicle.core.io.IOTools; +import net.openhft.chronicle.hash.*; +import net.openhft.chronicle.hash.impl.*; +import net.openhft.chronicle.hash.impl.stage.entry.*; +import net.openhft.chronicle.hash.impl.stage.hash.ChainingInterface; +import net.openhft.chronicle.hash.impl.util.Objects; import net.openhft.chronicle.hash.locks.InterProcessDeadLockException; import net.openhft.chronicle.hash.locks.InterProcessLock; -import net.openhft.chronicle.core.Jvm; -import net.openhft.chronicle.hash.impl.stage.entry.KeyHashCode; -import java.util.List; -import net.openhft.chronicle.hash.impl.LocalLockState; -import net.openhft.chronicle.hash.impl.stage.entry.LocksInterface; -import net.openhft.chronicle.algo.hashing.LongHashFunction; -import net.openhft.chronicle.map.MapAbsentEntry; -import net.openhft.chronicle.map.MapContext; -import net.openhft.chronicle.map.MapEntry; -import net.openhft.chronicle.algo.MemoryUnit; -import net.openhft.chronicle.bytes.NoBytesStore; -import net.openhft.chronicle.hash.impl.stage.entry.NoChecksumStrategy; -import org.jetbrains.annotations.NotNull; -import net.openhft.chronicle.hash.impl.util.Objects; -import net.openhft.chronicle.bytes.PointerBytesStore; -import java.util.function.Predicate; -import net.openhft.chronicle.bytes.RandomDataInput; -import net.openhft.chronicle.algo.bitset.ReusableBitSet; -import net.openhft.chronicle.hash.impl.SegmentHeader; -import net.openhft.chronicle.hash.SegmentLock; -import net.openhft.chronicle.set.SetContext; -import net.openhft.chronicle.algo.bitset.SingleThreadedFlatBitSetFrame; +import net.openhft.chronicle.hash.serialization.DataAccess; import net.openhft.chronicle.hash.serialization.SizedReader; -import net.openhft.chronicle.hash.impl.TierCountersArea; +import net.openhft.chronicle.map.*; +import net.openhft.chronicle.set.ChronicleSet; +import net.openhft.chronicle.set.SetContext; +import org.jetbrains.annotations.NotNull; + +import java.util.ArrayList; +import java.util.ConcurrentModificationException; +import java.util.List; import java.util.concurrent.TimeUnit; -import net.openhft.chronicle.bytes.VanillaBytes; -import net.openhft.chronicle.hash.impl.VanillaChronicleHash; -import net.openhft.chronicle.map.VanillaChronicleMap; -import net.openhft.chronicle.hash.VanillaGlobalMutableState; +import java.util.function.BiFunction; +import java.util.function.Consumer; +import java.util.function.Predicate; import static net.openhft.chronicle.hash.impl.LocalLockState.UNLOCKED; @@ -911,8 +882,8 @@ public void doCloseNext() { public void doCloseWrappedValueBytes() { if (!(this.wrappedValueBytesInit())) return ; - - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } @@ -1047,7 +1018,7 @@ void closeWrappedValueBytes() { return ; this.closeWrappedValueBytesDependants(); - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } diff --git a/src/main/java/net/openhft/chronicle/map/impl/CompiledMapQueryContext.java b/src/main/java/net/openhft/chronicle/map/impl/CompiledMapQueryContext.java index 5f1a4e8b4c..b46f88a096 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/CompiledMapQueryContext.java +++ b/src/main/java/net/openhft/chronicle/map/impl/CompiledMapQueryContext.java @@ -707,8 +707,8 @@ public void doCloseCachedInputKey() { public void doCloseInputKeyBytes() { if (!(this.inputKeyBytesInit())) return ; - - inputKeyBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + + inputKeyBytes.bytesStore(BytesStore.empty(), 0, 0); inputKeyBytesUsed = false; } @@ -793,7 +793,7 @@ void closeInputKeyBytes() { return ; this.closeInputKeyBytesDependants(); - inputKeyBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + inputKeyBytes.bytesStore(BytesStore.empty(), 0, 0); inputKeyBytesUsed = false; } @@ -1155,8 +1155,8 @@ public void doCloseNext() { public void doCloseWrappedValueBytes() { if (!(this.wrappedValueBytesInit())) return ; - - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } @@ -1291,7 +1291,7 @@ void closeWrappedValueBytes() { return ; this.closeWrappedValueBytesDependants(); - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } diff --git a/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapIterationContext.java b/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapIterationContext.java index a6f7ec4dae..abb6728cd5 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapIterationContext.java +++ b/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapIterationContext.java @@ -1038,8 +1038,8 @@ public void doCloseNext() { public void doCloseWrappedValueBytes() { if (!(this.wrappedValueBytesInit())) return ; - - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } @@ -1186,7 +1186,7 @@ void closeWrappedValueBytes() { return ; this.closeWrappedValueBytesDependants(); - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } diff --git a/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapQueryContext.java b/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapQueryContext.java index b9364f71b4..1647d40770 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapQueryContext.java +++ b/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapQueryContext.java @@ -736,8 +736,8 @@ public void doCloseCachedInputKey() { public void doCloseInputKeyBytes() { if (!(this.inputKeyBytesInit())) return ; - - inputKeyBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + + inputKeyBytes.bytesStore(BytesStore.empty(), 0, 0); inputKeyBytesUsed = false; } @@ -822,7 +822,7 @@ void closeInputKeyBytes() { return ; this.closeInputKeyBytesDependants(); - inputKeyBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + inputKeyBytes.bytesStore(BytesStore.empty(), 0, 0); inputKeyBytesUsed = false; } @@ -1215,8 +1215,8 @@ public void doCloseNext() { public void doCloseWrappedValueBytes() { if (!(this.wrappedValueBytesInit())) return ; - - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } @@ -1351,7 +1351,7 @@ void closeWrappedValueBytes() { return ; this.closeWrappedValueBytesDependants(); - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } diff --git a/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java b/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java index d94538ebd7..10d17ee04d 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java +++ b/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java @@ -158,17 +158,6 @@ public boolean compareAndSwapLong(long offset, long expected, long value) { return true; } - @Deprecated(/* to be removed in x.25 */) - @Override - public byte[] internalNumberBuffer() { - throw new UnsupportedOperationException(); - } - - @Override - public byte[] internalNumberBuffer() { - throw new UnsupportedOperationException(); - } - @Override public void reserve(ReferenceOwner id) throws IllegalStateException { } @@ -178,11 +167,6 @@ public boolean tryReserve(ReferenceOwner id) throws IllegalStateException { return false; } - @Override - public boolean reservedBy(ReferenceOwner owner) { - return true; - } - @Override public void release(ReferenceOwner id) throws IllegalStateException { } diff --git a/src/main/java/net/openhft/chronicle/map/impl/stage/data/bytes/WrappedValueBytesData.java b/src/main/java/net/openhft/chronicle/map/impl/stage/data/bytes/WrappedValueBytesData.java index 9144f0e2d6..3be42da23e 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/stage/data/bytes/WrappedValueBytesData.java +++ b/src/main/java/net/openhft/chronicle/map/impl/stage/data/bytes/WrappedValueBytesData.java @@ -26,8 +26,6 @@ import net.openhft.sg.StageRef; import net.openhft.sg.Staged; -import static net.openhft.chronicle.bytes.NoBytesStore.NO_BYTES_STORE; - @Staged public class WrappedValueBytesData extends AbstractData { @@ -95,7 +93,7 @@ void initWrappedValueBytes() { } void closeWrappedValueBytes() { - wrappedValueBytes.bytesStore(NO_BYTES_STORE, 0, 0); + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } diff --git a/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java b/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java index 6c6657b750..9aabf146f1 100644 --- a/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java +++ b/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java @@ -1174,7 +1174,7 @@ public ByteBuffer apply(ByteBuffer s) { MapEntry entry = c.entry(); assertNotNull(entry); - ByteBuffer bb1 = ByteBuffer.allocate(8); + ByteBuffer bb1 = ByteBuffer.allocate(8).order(ByteOrder.nativeOrder()); bb1.put(value1); bb1.putShort((short) 12345); bb1.flip(); diff --git a/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java b/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java index 60278fabd6..0182e6d84d 100644 --- a/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java +++ b/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java @@ -17,7 +17,7 @@ package net.openhft.chronicle.map; import com.google.common.collect.Lists; -import net.openhft.chronicle.bytes.NoBytesStore; +import net.openhft.chronicle.bytes.internal.NoBytesStore; import net.openhft.chronicle.core.Jvm; import net.openhft.chronicle.core.OS; import net.openhft.chronicle.core.values.IntValue; diff --git a/src/test/java/net/openhft/chronicle/map/channel/PerfMapHandlerMain.java b/src/test/java/net/openhft/chronicle/map/channel/PerfMapHandlerMain.java index aba04f4dab..1ecdedb731 100644 --- a/src/test/java/net/openhft/chronicle/map/channel/PerfMapHandlerMain.java +++ b/src/test/java/net/openhft/chronicle/map/channel/PerfMapHandlerMain.java @@ -4,10 +4,10 @@ import net.openhft.chronicle.bytes.Bytes; import net.openhft.chronicle.bytes.MethodReader; import net.openhft.chronicle.core.Jvm; -import net.openhft.chronicle.core.Mocker; import net.openhft.chronicle.core.OS; import net.openhft.chronicle.core.io.Closeable; import net.openhft.chronicle.core.io.IORuntimeException; +import net.openhft.chronicle.core.util.Mocker; import net.openhft.chronicle.hash.serialization.impl.BytesMarshallableReaderWriter; import net.openhft.chronicle.hash.serialization.impl.BytesSizedMarshaller; import net.openhft.chronicle.jlbh.JLBH; diff --git a/src/test/java/net/openhft/chronicle/map/ipc/StateMachineData.java b/src/test/java/net/openhft/chronicle/map/ipc/StateMachineData.java index fbcbb13677..efdc36696f 100644 --- a/src/test/java/net/openhft/chronicle/map/ipc/StateMachineData.java +++ b/src/test/java/net/openhft/chronicle/map/ipc/StateMachineData.java @@ -19,6 +19,9 @@ import net.openhft.chronicle.bytes.Byteable; import net.openhft.chronicle.bytes.BytesStore; +import java.io.IOException; +import java.nio.channels.FileLock; + /** * */ @@ -160,4 +163,14 @@ public long offset() { public long maxSize() { return 16; } + + @Override + public FileLock lock(boolean shared) throws IOException { + throw new UnsupportedOperationException(); + } + + @Override + public FileLock tryLock(boolean shared) throws IOException { + throw new UnsupportedOperationException(); + } } diff --git a/src/test/java/net/openhft/lang/values/DoubleArray.java b/src/test/java/net/openhft/lang/values/DoubleArray.java index 8bc921c0b0..bb53914d80 100644 --- a/src/test/java/net/openhft/lang/values/DoubleArray.java +++ b/src/test/java/net/openhft/lang/values/DoubleArray.java @@ -21,6 +21,9 @@ import net.openhft.chronicle.bytes.DynamicallySized; import net.openhft.chronicle.values.Copyable; +import java.io.IOException; +import java.nio.channels.FileLock; + /** * Created by peter.lawrey on 23/04/2015. */ @@ -62,6 +65,16 @@ public long maxSize() { return BASE + capacity * 8; } + @Override + public FileLock lock(boolean shared) throws IOException { + throw new UnsupportedOperationException(); + } + + @Override + public FileLock tryLock(boolean shared) throws IOException { + throw new UnsupportedOperationException(); + } + public int length() { return HACK && bs == null ? 6 * 8 : bs.readInt(LENGTH + offset); } From b22771ffd66c278c2bc639dc203c73cea716ef55 Mon Sep 17 00:00:00 2001 From: Peter Lawrey Date: Mon, 30 Oct 2023 12:11:35 +0000 Subject: [PATCH 6/9] totalMemory() to report the actual size with page alignment esp on Windows. --- .../openhft/chronicle/hash/impl/ChronicleHashResources.java | 4 +++- src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java | 4 ++++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/src/main/java/net/openhft/chronicle/hash/impl/ChronicleHashResources.java b/src/main/java/net/openhft/chronicle/hash/impl/ChronicleHashResources.java index a24508c106..5e4eab561a 100644 --- a/src/main/java/net/openhft/chronicle/hash/impl/ChronicleHashResources.java +++ b/src/main/java/net/openhft/chronicle/hash/impl/ChronicleHashResources.java @@ -17,6 +17,7 @@ package net.openhft.chronicle.hash.impl; import net.openhft.chronicle.core.Jvm; +import net.openhft.chronicle.core.OS; import net.openhft.chronicle.hash.ChronicleHashClosedException; import net.openhft.chronicle.hash.impl.stage.hash.ChainingInterface; import net.openhft.chronicle.hash.impl.util.Throwables; @@ -65,9 +66,10 @@ final synchronized long totalMemory() { if (closed()) return 0L; long totalMemory = 0L; + int pageSize = OS.defaultOsPageSize(); //noinspection ForLoopReplaceableByForEach -- allocation-free looping for (int i = 0; i < memoryResources.size(); i++) { - totalMemory += memoryResources.get(i).size; + totalMemory += OS.pageAlign(memoryResources.get(i).size, pageSize); } return totalMemory; } diff --git a/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java b/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java index 0182e6d84d..5a2efc532e 100644 --- a/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java +++ b/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java @@ -20,6 +20,7 @@ import net.openhft.chronicle.bytes.internal.NoBytesStore; import net.openhft.chronicle.core.Jvm; import net.openhft.chronicle.core.OS; +import net.openhft.chronicle.core.io.AbstractCloseable; import net.openhft.chronicle.core.values.IntValue; import net.openhft.chronicle.hash.impl.util.Cleaner; import net.openhft.chronicle.hash.impl.util.CleanerUtils; @@ -104,6 +105,9 @@ public void resetSerializerCount() { @Test(timeout = 10_000) public void testChronicleMapCollectedAndDirectMemoryReleased() throws IOException { + // check previous resources have been closed + AbstractCloseable.assertCloseablesClosed(); + assumeFalse(OS.isMacOSX()); // This test is flaky in Linux and Mac OS apparently because some native memory from // running previous/concurrent tests is released during this test, that infers with From 8501e5bff5113d0b96922e31345b89b2de95c368 Mon Sep 17 00:00:00 2001 From: "yevgen.pavlenko" Date: Mon, 23 Oct 2023 18:29:41 +0300 Subject: [PATCH 7/9] Remove deprecated code. --- pom.xml | 1 - .../hash/impl/VanillaChronicleHash.java | 5 +- .../stage/data/bytes/InputKeyBytesData.java | 4 +- .../impl/util/CanonicalRandomAccessFiles.java | 2 +- .../impl/BytesMarshallableDataAccess.java | 2 +- .../impl/SizedMarshallableDataAccess.java | 2 +- .../map/impl/CompiledMapIterationContext.java | 83 ++++++------------- .../map/impl/CompiledMapQueryContext.java | 12 +-- ...CompiledReplicatedMapIterationContext.java | 6 +- .../CompiledReplicatedMapQueryContext.java | 12 +-- .../map/impl/stage/data/ZeroBytesStore.java | 16 ---- .../data/bytes/WrappedValueBytesData.java | 4 +- .../chronicle/map/CHMUseCasesTest.java | 2 +- .../chronicle/map/MemoryLeaksTest.java | 2 +- .../map/channel/PerfMapHandlerMain.java | 2 +- .../chronicle/map/ipc/StateMachineData.java | 13 +++ .../net/openhft/lang/values/DoubleArray.java | 13 +++ 17 files changed, 77 insertions(+), 104 deletions(-) diff --git a/pom.xml b/pom.xml index 5472221dbd..3767b2e49e 100644 --- a/pom.xml +++ b/pom.xml @@ -72,7 +72,6 @@ net.openhft chronicle-bytes - 2.24ea19 diff --git a/src/main/java/net/openhft/chronicle/hash/impl/VanillaChronicleHash.java b/src/main/java/net/openhft/chronicle/hash/impl/VanillaChronicleHash.java index b56d542cbd..462917c437 100644 --- a/src/main/java/net/openhft/chronicle/hash/impl/VanillaChronicleHash.java +++ b/src/main/java/net/openhft/chronicle/hash/impl/VanillaChronicleHash.java @@ -224,8 +224,6 @@ public VanillaChronicleHash(@NotNull final ChronicleMapBuilder builder) { preShutdownAction = privateAPI.getPreShutdownAction(); skipCloseOnExitHook = privateAPI.skipCloseOnExitHook(); - - disableThreadSafetyCheck(true); } public static IOException throwRecoveryOrReturnIOException(@NotNull final File file, @@ -934,8 +932,7 @@ private void allocateTierBulk() { globalMutableState.addDataStoreSize(tierBulkSizeInBytes); } - // TODO: x.25 remove throws IOException - public void msync() throws IOException { + public void msync() { throwExceptionIfClosed(); if (persisted()) { diff --git a/src/main/java/net/openhft/chronicle/hash/impl/stage/data/bytes/InputKeyBytesData.java b/src/main/java/net/openhft/chronicle/hash/impl/stage/data/bytes/InputKeyBytesData.java index 6fdb3b4a47..e7690eaeb4 100644 --- a/src/main/java/net/openhft/chronicle/hash/impl/stage/data/bytes/InputKeyBytesData.java +++ b/src/main/java/net/openhft/chronicle/hash/impl/stage/data/bytes/InputKeyBytesData.java @@ -26,8 +26,6 @@ import net.openhft.sg.StageRef; import net.openhft.sg.Staged; -import static net.openhft.chronicle.bytes.NoBytesStore.NO_BYTES_STORE; - @Staged public class InputKeyBytesData extends AbstractData { @@ -66,7 +64,7 @@ void initInputKeyBytes() { } void closeInputKeyBytes() { - inputKeyBytes.bytesStore(NO_BYTES_STORE, 0, 0); + inputKeyBytes.bytesStore(BytesStore.empty(), 0, 0); inputKeyBytesUsed = false; } diff --git a/src/main/java/net/openhft/chronicle/hash/impl/util/CanonicalRandomAccessFiles.java b/src/main/java/net/openhft/chronicle/hash/impl/util/CanonicalRandomAccessFiles.java index 3e0a31d37d..87efc65c57 100644 --- a/src/main/java/net/openhft/chronicle/hash/impl/util/CanonicalRandomAccessFiles.java +++ b/src/main/java/net/openhft/chronicle/hash/impl/util/CanonicalRandomAccessFiles.java @@ -16,9 +16,9 @@ package net.openhft.chronicle.hash.impl.util; -import net.openhft.chronicle.core.CleaningRandomAccessFile; import net.openhft.chronicle.core.Jvm; import net.openhft.chronicle.core.OS; +import net.openhft.chronicle.core.io.CleaningRandomAccessFile; import net.openhft.chronicle.hash.ChronicleFileLockException; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; diff --git a/src/main/java/net/openhft/chronicle/hash/serialization/impl/BytesMarshallableDataAccess.java b/src/main/java/net/openhft/chronicle/hash/serialization/impl/BytesMarshallableDataAccess.java index ee2d024526..7f0b30aed8 100644 --- a/src/main/java/net/openhft/chronicle/hash/serialization/impl/BytesMarshallableDataAccess.java +++ b/src/main/java/net/openhft/chronicle/hash/serialization/impl/BytesMarshallableDataAccess.java @@ -94,7 +94,7 @@ public void writeTo(RandomDataOutput target, long targetOffset) { target.capacity() - targetOffset); targetBytes.writePosition(targetOffset); instance.writeMarshallable(targetBytes); - targetBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + targetBytes.bytesStore(BytesStore.empty(), 0, 0); } } diff --git a/src/main/java/net/openhft/chronicle/hash/serialization/impl/SizedMarshallableDataAccess.java b/src/main/java/net/openhft/chronicle/hash/serialization/impl/SizedMarshallableDataAccess.java index 57b790df36..765ef381c0 100644 --- a/src/main/java/net/openhft/chronicle/hash/serialization/impl/SizedMarshallableDataAccess.java +++ b/src/main/java/net/openhft/chronicle/hash/serialization/impl/SizedMarshallableDataAccess.java @@ -104,7 +104,7 @@ public void writeTo(RandomDataOutput target, long targetOffset) { targetBytes.bytesStore((BytesStore) target, targetOffset, size); targetBytes.writePosition(targetOffset); sizedWriter.write(targetBytes, size, instance); - targetBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + targetBytes.bytesStore(BytesStore.empty(), 0, 0); } } diff --git a/src/main/java/net/openhft/chronicle/map/impl/CompiledMapIterationContext.java b/src/main/java/net/openhft/chronicle/map/impl/CompiledMapIterationContext.java index 871956cb0d..80639fa492 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/CompiledMapIterationContext.java +++ b/src/main/java/net/openhft/chronicle/map/impl/CompiledMapIterationContext.java @@ -1,64 +1,35 @@ package net.openhft.chronicle.map.impl; -import net.openhft.chronicle.hash.AbstractData; -import net.openhft.chronicle.algo.bytes.Access; -import net.openhft.chronicle.hash.impl.stage.entry.Alloc; -import java.util.ArrayList; -import java.util.function.BiFunction; -import net.openhft.chronicle.hash.impl.BigSegmentHeader; +import net.openhft.chronicle.algo.MemoryUnit; import net.openhft.chronicle.algo.bitset.BitSetFrame; -import net.openhft.chronicle.bytes.Bytes; -import net.openhft.chronicle.bytes.BytesStore; -import net.openhft.chronicle.bytes.BytesUtil; -import net.openhft.chronicle.hash.impl.stage.hash.ChainingInterface; -import net.openhft.chronicle.hash.ChecksumEntry; -import net.openhft.chronicle.hash.impl.stage.entry.ChecksumStrategy; -import net.openhft.chronicle.hash.ChronicleHash; -import net.openhft.chronicle.hash.ChronicleHashCorruption; -import net.openhft.chronicle.map.ChronicleHashCorruptionImpl; -import net.openhft.chronicle.hash.ChronicleHashRecoveryFailedException; -import net.openhft.chronicle.map.ChronicleMap; -import net.openhft.chronicle.set.ChronicleSet; -import net.openhft.chronicle.hash.impl.CompactOffHeapLinearHashTable; -import java.util.ConcurrentModificationException; -import java.util.function.Consumer; -import net.openhft.chronicle.hash.Data; -import net.openhft.chronicle.hash.serialization.DataAccess; -import net.openhft.chronicle.map.ExternalMapQueryContext; -import net.openhft.chronicle.hash.HashEntry; -import net.openhft.chronicle.hash.HashSegmentContext; +import net.openhft.chronicle.algo.bitset.ReusableBitSet; +import net.openhft.chronicle.algo.bitset.SingleThreadedFlatBitSetFrame; +import net.openhft.chronicle.algo.bytes.Access; +import net.openhft.chronicle.algo.hashing.LongHashFunction; +import net.openhft.chronicle.bytes.*; +import net.openhft.chronicle.core.Jvm; import net.openhft.chronicle.core.io.IOTools; +import net.openhft.chronicle.hash.*; +import net.openhft.chronicle.hash.impl.*; +import net.openhft.chronicle.hash.impl.stage.entry.*; +import net.openhft.chronicle.hash.impl.stage.hash.ChainingInterface; +import net.openhft.chronicle.hash.impl.util.Objects; import net.openhft.chronicle.hash.locks.InterProcessDeadLockException; import net.openhft.chronicle.hash.locks.InterProcessLock; -import net.openhft.chronicle.core.Jvm; -import net.openhft.chronicle.hash.impl.stage.entry.KeyHashCode; -import java.util.List; -import net.openhft.chronicle.hash.impl.LocalLockState; -import net.openhft.chronicle.hash.impl.stage.entry.LocksInterface; -import net.openhft.chronicle.algo.hashing.LongHashFunction; -import net.openhft.chronicle.map.MapAbsentEntry; -import net.openhft.chronicle.map.MapContext; -import net.openhft.chronicle.map.MapEntry; -import net.openhft.chronicle.algo.MemoryUnit; -import net.openhft.chronicle.bytes.NoBytesStore; -import net.openhft.chronicle.hash.impl.stage.entry.NoChecksumStrategy; -import org.jetbrains.annotations.NotNull; -import net.openhft.chronicle.hash.impl.util.Objects; -import net.openhft.chronicle.bytes.PointerBytesStore; -import java.util.function.Predicate; -import net.openhft.chronicle.bytes.RandomDataInput; -import net.openhft.chronicle.algo.bitset.ReusableBitSet; -import net.openhft.chronicle.hash.impl.SegmentHeader; -import net.openhft.chronicle.hash.SegmentLock; -import net.openhft.chronicle.set.SetContext; -import net.openhft.chronicle.algo.bitset.SingleThreadedFlatBitSetFrame; +import net.openhft.chronicle.hash.serialization.DataAccess; import net.openhft.chronicle.hash.serialization.SizedReader; -import net.openhft.chronicle.hash.impl.TierCountersArea; +import net.openhft.chronicle.map.*; +import net.openhft.chronicle.set.ChronicleSet; +import net.openhft.chronicle.set.SetContext; +import org.jetbrains.annotations.NotNull; + +import java.util.ArrayList; +import java.util.ConcurrentModificationException; +import java.util.List; import java.util.concurrent.TimeUnit; -import net.openhft.chronicle.bytes.VanillaBytes; -import net.openhft.chronicle.hash.impl.VanillaChronicleHash; -import net.openhft.chronicle.map.VanillaChronicleMap; -import net.openhft.chronicle.hash.VanillaGlobalMutableState; +import java.util.function.BiFunction; +import java.util.function.Consumer; +import java.util.function.Predicate; import static net.openhft.chronicle.hash.impl.LocalLockState.UNLOCKED; @@ -911,8 +882,8 @@ public void doCloseNext() { public void doCloseWrappedValueBytes() { if (!(this.wrappedValueBytesInit())) return ; - - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } @@ -1047,7 +1018,7 @@ void closeWrappedValueBytes() { return ; this.closeWrappedValueBytesDependants(); - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } diff --git a/src/main/java/net/openhft/chronicle/map/impl/CompiledMapQueryContext.java b/src/main/java/net/openhft/chronicle/map/impl/CompiledMapQueryContext.java index 5f1a4e8b4c..b46f88a096 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/CompiledMapQueryContext.java +++ b/src/main/java/net/openhft/chronicle/map/impl/CompiledMapQueryContext.java @@ -707,8 +707,8 @@ public void doCloseCachedInputKey() { public void doCloseInputKeyBytes() { if (!(this.inputKeyBytesInit())) return ; - - inputKeyBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + + inputKeyBytes.bytesStore(BytesStore.empty(), 0, 0); inputKeyBytesUsed = false; } @@ -793,7 +793,7 @@ void closeInputKeyBytes() { return ; this.closeInputKeyBytesDependants(); - inputKeyBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + inputKeyBytes.bytesStore(BytesStore.empty(), 0, 0); inputKeyBytesUsed = false; } @@ -1155,8 +1155,8 @@ public void doCloseNext() { public void doCloseWrappedValueBytes() { if (!(this.wrappedValueBytesInit())) return ; - - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } @@ -1291,7 +1291,7 @@ void closeWrappedValueBytes() { return ; this.closeWrappedValueBytesDependants(); - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } diff --git a/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapIterationContext.java b/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapIterationContext.java index a6f7ec4dae..abb6728cd5 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapIterationContext.java +++ b/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapIterationContext.java @@ -1038,8 +1038,8 @@ public void doCloseNext() { public void doCloseWrappedValueBytes() { if (!(this.wrappedValueBytesInit())) return ; - - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } @@ -1186,7 +1186,7 @@ void closeWrappedValueBytes() { return ; this.closeWrappedValueBytesDependants(); - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } diff --git a/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapQueryContext.java b/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapQueryContext.java index b9364f71b4..1647d40770 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapQueryContext.java +++ b/src/main/java/net/openhft/chronicle/map/impl/CompiledReplicatedMapQueryContext.java @@ -736,8 +736,8 @@ public void doCloseCachedInputKey() { public void doCloseInputKeyBytes() { if (!(this.inputKeyBytesInit())) return ; - - inputKeyBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + + inputKeyBytes.bytesStore(BytesStore.empty(), 0, 0); inputKeyBytesUsed = false; } @@ -822,7 +822,7 @@ void closeInputKeyBytes() { return ; this.closeInputKeyBytesDependants(); - inputKeyBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + inputKeyBytes.bytesStore(BytesStore.empty(), 0, 0); inputKeyBytesUsed = false; } @@ -1215,8 +1215,8 @@ public void doCloseNext() { public void doCloseWrappedValueBytes() { if (!(this.wrappedValueBytesInit())) return ; - - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } @@ -1351,7 +1351,7 @@ void closeWrappedValueBytes() { return ; this.closeWrappedValueBytesDependants(); - wrappedValueBytes.bytesStore(NoBytesStore.NO_BYTES_STORE, 0, 0); + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } diff --git a/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java b/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java index d94538ebd7..10d17ee04d 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java +++ b/src/main/java/net/openhft/chronicle/map/impl/stage/data/ZeroBytesStore.java @@ -158,17 +158,6 @@ public boolean compareAndSwapLong(long offset, long expected, long value) { return true; } - @Deprecated(/* to be removed in x.25 */) - @Override - public byte[] internalNumberBuffer() { - throw new UnsupportedOperationException(); - } - - @Override - public byte[] internalNumberBuffer() { - throw new UnsupportedOperationException(); - } - @Override public void reserve(ReferenceOwner id) throws IllegalStateException { } @@ -178,11 +167,6 @@ public boolean tryReserve(ReferenceOwner id) throws IllegalStateException { return false; } - @Override - public boolean reservedBy(ReferenceOwner owner) { - return true; - } - @Override public void release(ReferenceOwner id) throws IllegalStateException { } diff --git a/src/main/java/net/openhft/chronicle/map/impl/stage/data/bytes/WrappedValueBytesData.java b/src/main/java/net/openhft/chronicle/map/impl/stage/data/bytes/WrappedValueBytesData.java index 9144f0e2d6..3be42da23e 100644 --- a/src/main/java/net/openhft/chronicle/map/impl/stage/data/bytes/WrappedValueBytesData.java +++ b/src/main/java/net/openhft/chronicle/map/impl/stage/data/bytes/WrappedValueBytesData.java @@ -26,8 +26,6 @@ import net.openhft.sg.StageRef; import net.openhft.sg.Staged; -import static net.openhft.chronicle.bytes.NoBytesStore.NO_BYTES_STORE; - @Staged public class WrappedValueBytesData extends AbstractData { @@ -95,7 +93,7 @@ void initWrappedValueBytes() { } void closeWrappedValueBytes() { - wrappedValueBytes.bytesStore(NO_BYTES_STORE, 0, 0); + wrappedValueBytes.bytesStore(BytesStore.empty(), 0, 0); wrappedValueBytesUsed = false; } diff --git a/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java b/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java index 6c6657b750..9aabf146f1 100644 --- a/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java +++ b/src/test/java/net/openhft/chronicle/map/CHMUseCasesTest.java @@ -1174,7 +1174,7 @@ public ByteBuffer apply(ByteBuffer s) { MapEntry entry = c.entry(); assertNotNull(entry); - ByteBuffer bb1 = ByteBuffer.allocate(8); + ByteBuffer bb1 = ByteBuffer.allocate(8).order(ByteOrder.nativeOrder()); bb1.put(value1); bb1.putShort((short) 12345); bb1.flip(); diff --git a/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java b/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java index 60278fabd6..0182e6d84d 100644 --- a/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java +++ b/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java @@ -17,7 +17,7 @@ package net.openhft.chronicle.map; import com.google.common.collect.Lists; -import net.openhft.chronicle.bytes.NoBytesStore; +import net.openhft.chronicle.bytes.internal.NoBytesStore; import net.openhft.chronicle.core.Jvm; import net.openhft.chronicle.core.OS; import net.openhft.chronicle.core.values.IntValue; diff --git a/src/test/java/net/openhft/chronicle/map/channel/PerfMapHandlerMain.java b/src/test/java/net/openhft/chronicle/map/channel/PerfMapHandlerMain.java index aba04f4dab..1ecdedb731 100644 --- a/src/test/java/net/openhft/chronicle/map/channel/PerfMapHandlerMain.java +++ b/src/test/java/net/openhft/chronicle/map/channel/PerfMapHandlerMain.java @@ -4,10 +4,10 @@ import net.openhft.chronicle.bytes.Bytes; import net.openhft.chronicle.bytes.MethodReader; import net.openhft.chronicle.core.Jvm; -import net.openhft.chronicle.core.Mocker; import net.openhft.chronicle.core.OS; import net.openhft.chronicle.core.io.Closeable; import net.openhft.chronicle.core.io.IORuntimeException; +import net.openhft.chronicle.core.util.Mocker; import net.openhft.chronicle.hash.serialization.impl.BytesMarshallableReaderWriter; import net.openhft.chronicle.hash.serialization.impl.BytesSizedMarshaller; import net.openhft.chronicle.jlbh.JLBH; diff --git a/src/test/java/net/openhft/chronicle/map/ipc/StateMachineData.java b/src/test/java/net/openhft/chronicle/map/ipc/StateMachineData.java index fbcbb13677..efdc36696f 100644 --- a/src/test/java/net/openhft/chronicle/map/ipc/StateMachineData.java +++ b/src/test/java/net/openhft/chronicle/map/ipc/StateMachineData.java @@ -19,6 +19,9 @@ import net.openhft.chronicle.bytes.Byteable; import net.openhft.chronicle.bytes.BytesStore; +import java.io.IOException; +import java.nio.channels.FileLock; + /** * */ @@ -160,4 +163,14 @@ public long offset() { public long maxSize() { return 16; } + + @Override + public FileLock lock(boolean shared) throws IOException { + throw new UnsupportedOperationException(); + } + + @Override + public FileLock tryLock(boolean shared) throws IOException { + throw new UnsupportedOperationException(); + } } diff --git a/src/test/java/net/openhft/lang/values/DoubleArray.java b/src/test/java/net/openhft/lang/values/DoubleArray.java index 8bc921c0b0..bb53914d80 100644 --- a/src/test/java/net/openhft/lang/values/DoubleArray.java +++ b/src/test/java/net/openhft/lang/values/DoubleArray.java @@ -21,6 +21,9 @@ import net.openhft.chronicle.bytes.DynamicallySized; import net.openhft.chronicle.values.Copyable; +import java.io.IOException; +import java.nio.channels.FileLock; + /** * Created by peter.lawrey on 23/04/2015. */ @@ -62,6 +65,16 @@ public long maxSize() { return BASE + capacity * 8; } + @Override + public FileLock lock(boolean shared) throws IOException { + throw new UnsupportedOperationException(); + } + + @Override + public FileLock tryLock(boolean shared) throws IOException { + throw new UnsupportedOperationException(); + } + public int length() { return HACK && bs == null ? 6 * 8 : bs.readInt(LENGTH + offset); } From dab975db027019b8e4ee5a179c61113bc85bc838 Mon Sep 17 00:00:00 2001 From: Peter Lawrey Date: Mon, 30 Oct 2023 12:37:14 +0000 Subject: [PATCH 8/9] VanillaChronicleHash.map to use the actual aligned size. --- .../chronicle/hash/impl/ChronicleHashResources.java | 4 +--- .../openhft/chronicle/hash/impl/VanillaChronicleHash.java | 5 +++-- .../java/net/openhft/chronicle/map/MemoryLeaksTest.java | 7 +++++-- 3 files changed, 9 insertions(+), 7 deletions(-) diff --git a/src/main/java/net/openhft/chronicle/hash/impl/ChronicleHashResources.java b/src/main/java/net/openhft/chronicle/hash/impl/ChronicleHashResources.java index 5e4eab561a..a24508c106 100644 --- a/src/main/java/net/openhft/chronicle/hash/impl/ChronicleHashResources.java +++ b/src/main/java/net/openhft/chronicle/hash/impl/ChronicleHashResources.java @@ -17,7 +17,6 @@ package net.openhft.chronicle.hash.impl; import net.openhft.chronicle.core.Jvm; -import net.openhft.chronicle.core.OS; import net.openhft.chronicle.hash.ChronicleHashClosedException; import net.openhft.chronicle.hash.impl.stage.hash.ChainingInterface; import net.openhft.chronicle.hash.impl.util.Throwables; @@ -66,10 +65,9 @@ final synchronized long totalMemory() { if (closed()) return 0L; long totalMemory = 0L; - int pageSize = OS.defaultOsPageSize(); //noinspection ForLoopReplaceableByForEach -- allocation-free looping for (int i = 0; i < memoryResources.size(); i++) { - totalMemory += OS.pageAlign(memoryResources.get(i).size, pageSize); + totalMemory += memoryResources.get(i).size; } return totalMemory; } diff --git a/src/main/java/net/openhft/chronicle/hash/impl/VanillaChronicleHash.java b/src/main/java/net/openhft/chronicle/hash/impl/VanillaChronicleHash.java index 462917c437..d861754b15 100644 --- a/src/main/java/net/openhft/chronicle/hash/impl/VanillaChronicleHash.java +++ b/src/main/java/net/openhft/chronicle/hash/impl/VanillaChronicleHash.java @@ -1070,7 +1070,8 @@ private void mapTierBulksMapped(final int upToBulkIndex) throws IOException { * @see net.openhft.chronicle.bytes.MappedFile#acquireByteStore(ReferenceOwner, long, BytesStore, MappedBytesStoreFactory) */ private BytesStore map(long mapSize, final long mappingOffsetInFile) throws IOException { - mapSize = pageAlign(mapSize); + int pageSize = (int) OS.mapAlignment(); + mapSize = pageAlign(mapSize, pageSize); final long minFileSize = mappingOffsetInFile + mapSize; final FileChannel fileChannel = raf.getChannel(); if (fileChannel.size() < minFileSize) { @@ -1091,7 +1092,7 @@ private BytesStore map(long mapSize, final long mappingOffsetInFile) throws IOEx fallocate(mappingOffsetInFile, minFileSize - mappingOffsetInFile); } } - final long address = OS.map(fileChannel, READ_WRITE, mappingOffsetInFile, mapSize); + final long address = OS.map(fileChannel, READ_WRITE, mappingOffsetInFile, mapSize, pageSize); resources.addMemoryResource(address, mapSize); return BytesStore.wrap(address, mapSize); } diff --git a/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java b/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java index 5a2efc532e..3b074ee4cb 100644 --- a/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java +++ b/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java @@ -124,8 +124,11 @@ public void testChronicleMapCollectedAndDirectMemoryReleased() throws IOExceptio // the purpose of the test is to find maps which are not closed properly. ChronicleMap map = getMap(); long expectedNativeMemory = nativeMemoryUsedBeforeMap + map.offHeapMemoryUsed(); - assertEquals(expectedNativeMemory, nativeMemoryUsed()); - tryCloseFromContext(map); + try { + assertEquals(expectedNativeMemory, nativeMemoryUsed()); + } finally { + tryCloseFromContext(map); + } WeakReference> ref = new WeakReference<>(map); Assert.assertNotNull(ref.get()); //noinspection UnusedAssignment From bf1d65f844eb569bd5607e401fc3f61b59218d51 Mon Sep 17 00:00:00 2001 From: Peter Lawrey Date: Mon, 30 Oct 2023 12:43:50 +0000 Subject: [PATCH 9/9] Remove reference to bytes.internal package --- .../net/openhft/chronicle/map/MemoryLeaksTest.java | 10 ---------- 1 file changed, 10 deletions(-) diff --git a/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java b/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java index 3b074ee4cb..5c2da25f82 100644 --- a/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java +++ b/src/test/java/net/openhft/chronicle/map/MemoryLeaksTest.java @@ -17,10 +17,8 @@ package net.openhft.chronicle.map; import com.google.common.collect.Lists; -import net.openhft.chronicle.bytes.internal.NoBytesStore; import net.openhft.chronicle.core.Jvm; import net.openhft.chronicle.core.OS; -import net.openhft.chronicle.core.io.AbstractCloseable; import net.openhft.chronicle.core.values.IntValue; import net.openhft.chronicle.hash.impl.util.Cleaner; import net.openhft.chronicle.hash.impl.util.CleanerUtils; @@ -92,11 +90,6 @@ private static String named(final List flags) { (!flags.get(2) ? "not " : "") + "closed within context"; } - @Before - public void initNoBytesStore() { - Assert.assertNotEquals(0, NoBytesStore.NO_PAGE); - } - @Before public void resetSerializerCount() { System.err.println("This test is expect to print 'ChronicleMap ... is not closed manually, cleaned up from Cleaner'"); @@ -105,9 +98,6 @@ public void resetSerializerCount() { @Test(timeout = 10_000) public void testChronicleMapCollectedAndDirectMemoryReleased() throws IOException { - // check previous resources have been closed - AbstractCloseable.assertCloseablesClosed(); - assumeFalse(OS.isMacOSX()); // This test is flaky in Linux and Mac OS apparently because some native memory from // running previous/concurrent tests is released during this test, that infers with