All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.questdb.network.IOContextFactoryImpl Maven / Gradle / Ivy

/*******************************************************************************
 *     ___                  _   ____  ____
 *    / _ \ _   _  ___  ___| |_|  _ \| __ )
 *   | | | | | | |/ _ \/ __| __| | | |  _ \
 *   | |_| | |_| |  __/\__ \ |_| |_| | |_) |
 *    \__\_\\__,_|\___||___/\__|____/|____/
 *
 *  Copyright (c) 2014-2019 Appsicle
 *  Copyright (c) 2019-2023 QuestDB
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *  http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 *
 ******************************************************************************/

package io.questdb.network;

import io.questdb.mp.EagerThreadSetup;
import io.questdb.std.Misc;
import io.questdb.std.ObjectFactory;
import io.questdb.std.ThreadLocal;
import io.questdb.std.WeakMutableObjectPool;

import java.io.Closeable;

public class IOContextFactoryImpl> implements IOContextFactory, Closeable, EagerThreadSetup {

    private final ThreadLocal> contextPool;
    private volatile boolean closed = false;

    public IOContextFactoryImpl(ObjectFactory factory, int poolSize) {
        // todo: this is very slow, refactor
        this.contextPool = new ThreadLocal<>(() -> new WeakMutableObjectPool<>(factory, poolSize));
    }

    @Override
    public void close() {
        closed = true;
    }

    @Override
    public void done(C context) {
        if (closed) {
            Misc.free(context);
        } else {
            context.of(-1, null);
            contextPool.get().push(context);
        }
    }

    public void freeThreadLocal() {
        // helper call, it will free only thread-local instance and not others
        Misc.free(this.contextPool);
    }

    public C newInstance(int fd, IODispatcher dispatcher) {
        return contextPool.get().pop().of(fd, dispatcher);
    }

    @Override
    public void setup() {
        contextPool.get();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy