mirror of
https://github.com/corda/corda.git
synced 2025-01-22 12:28:11 +00:00
clean up OS resources immediately upon thread exit
Previously, we waited until the next GC to do this, but that can be too long for workloads which create a lot of short-lived threads but don't do much allocation.
This commit is contained in:
parent
44f55673d6
commit
f64d6c857b
@ -45,7 +45,11 @@ void
|
|||||||
join(Thread* t, Thread* o)
|
join(Thread* t, Thread* o)
|
||||||
{
|
{
|
||||||
if (t != o) {
|
if (t != o) {
|
||||||
|
if (o->state != Thread::ZombieState
|
||||||
|
and o->state != Thread::JoinedState)
|
||||||
|
{
|
||||||
o->systemThread->join();
|
o->systemThread->join();
|
||||||
|
}
|
||||||
o->state = Thread::JoinedState;
|
o->state = Thread::JoinedState;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2281,6 +2285,12 @@ Thread::exit()
|
|||||||
} else {
|
} else {
|
||||||
threadPeer(this, javaThread) = 0;
|
threadPeer(this, javaThread) = 0;
|
||||||
enter(this, Thread::ZombieState);
|
enter(this, Thread::ZombieState);
|
||||||
|
|
||||||
|
lock->dispose();
|
||||||
|
lock = 0;
|
||||||
|
|
||||||
|
systemThread->dispose();
|
||||||
|
systemThread = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2288,7 +2298,9 @@ Thread::exit()
|
|||||||
void
|
void
|
||||||
Thread::dispose()
|
Thread::dispose()
|
||||||
{
|
{
|
||||||
|
if (lock) {
|
||||||
lock->dispose();
|
lock->dispose();
|
||||||
|
}
|
||||||
|
|
||||||
if (systemThread) {
|
if (systemThread) {
|
||||||
systemThread->dispose();
|
systemThread->dispose();
|
||||||
|
@ -2745,9 +2745,13 @@ notifyAll(Thread* t, object o)
|
|||||||
|
|
||||||
inline void
|
inline void
|
||||||
interrupt(Thread*, Thread* target)
|
interrupt(Thread*, Thread* target)
|
||||||
|
{
|
||||||
|
if (target->state != Thread::ZombieState
|
||||||
|
and target->state != Thread::JoinedState)
|
||||||
{
|
{
|
||||||
target->systemThread->interrupt();
|
target->systemThread->interrupt();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
inline void
|
inline void
|
||||||
setDaemon(Thread* t, object thread, bool daemon)
|
setDaemon(Thread* t, object thread, bool daemon)
|
||||||
|
Loading…
Reference in New Issue
Block a user