Home / File/ ResourceLeakTracker.java — netty Source File

ResourceLeakTracker.java — netty Source File

Architecture documentation for ResourceLeakTracker.java, a java file in the netty codebase.

Entity Profile

Relationship Graph

Source Code

/*
 * Copyright 2016 The Netty Project
 *
 * The Netty Project licenses this file to you 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:
 *
 *   https://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.netty.util;

import org.jetbrains.annotations.Nullable;

public interface ResourceLeakTracker<T>  {

    /**
     * Records the caller's current stack trace so that the {@link ResourceLeakDetector} can tell where the leaked
     * resource was accessed lastly. This method is a shortcut to {@link #record(Object) record(null)}.
     */
    void record();

    /**
     * Records the caller's current stack trace and the specified additional arbitrary information
     * so that the {@link ResourceLeakDetector} can tell where the leaked resource was accessed lastly.
     */
    void record(Object hint);

    /**
     * Close the leak so that {@link ResourceLeakTracker} does not warn about leaked resources.
     * After this method is called a leak associated with this ResourceLeakTracker should not be reported.
     *
     * @return {@code true} if called first time, {@code false} if called already
     */
    boolean close(T trackedObject);

    /**
     * Get a {@link Throwable} representing the stack trace of the original {@link #close(Object)} call.
     * If this tracker hasn't been cloesd, or close tracking isn't supported or enabled,
     * then this method returns {@code null}.
     *
     * @return A throwable with the stack trace of the successful close call, or {@code null}.
     */
    default @Nullable Throwable getCloseStackTraceIfAny() {
        return null;
    }
}

Frequently Asked Questions

What does ResourceLeakTracker.java do?
ResourceLeakTracker.java is a source file in the netty codebase, written in java.
Where is ResourceLeakTracker.java in the architecture?
ResourceLeakTracker.java is located at common/src/main/java/io/netty/util/ResourceLeakTracker.java (directory: common/src/main/java/io/netty/util).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free