3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-10-24 00:14:35 +00:00

Bugfix for concurrent garbage collection in Java API.

Relates to #205 and #245
This commit is contained in:
Christoph M. Wintersteiger 2015-10-14 12:42:27 +01:00
parent 2d2ec38541
commit 6263252bf5
2 changed files with 34 additions and 19 deletions

View file

@ -18,6 +18,7 @@ Notes:
package com.microsoft.z3;
import java.util.Map;
import java.util.concurrent.atomic.AtomicInteger;
import com.microsoft.z3.enumerations.Z3_ast_print_mode;
@ -3761,16 +3762,18 @@ public class Context extends IDisposable
return m_Optimize_DRQ;
}
protected long m_refCount = 0;
protected AtomicInteger m_refCount = new AtomicInteger(0);
/**
* Finalizer.
* @throws Throwable
**/
protected void finalize()
protected void finalize() throws Throwable
{
try {
dispose();
if (m_refCount == 0)
if (m_refCount.get() == 0)
{
try
{
@ -3780,10 +3783,21 @@ public class Context extends IDisposable
// OK.
}
m_ctx = 0;
System.out.println("> disposed OK.");
}
/*
else if (m_refCount.get() < 0)
System.out.println("XXX negative ref count");
else
CMW: re-queue the finalizer? */
{
System.out.println("XXX context not disposed");
}
}
catch (Throwable t) {
throw t;
}
finally {
super.finalize();
}
}
/**
@ -3791,6 +3805,7 @@ public class Context extends IDisposable
**/
public void dispose()
{
System.out.println("> context disposing.");
m_AST_DRQ.clear(this);
m_ASTMap_DRQ.clear(this);
m_ASTVector_DRQ.clear(this);

View file

@ -44,7 +44,7 @@ public class Z3Object extends IDisposable
if (m_ctx != null)
{
m_ctx.m_refCount--;
m_ctx.m_refCount.decrementAndGet();
m_ctx = null;
}
}
@ -54,13 +54,13 @@ public class Z3Object extends IDisposable
Z3Object(Context ctx)
{
ctx.m_refCount++;
ctx.m_refCount.incrementAndGet();
m_ctx = ctx;
}
Z3Object(Context ctx, long obj)
{
ctx.m_refCount++;
ctx.m_refCount.incrementAndGet();
m_ctx = ctx;
incRef(obj);
m_n_obj = obj;