/* * Copyright (c) Meta Platforms, Inc. and affiliates. * * 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. */ #pragma once namespace folly { /** * DestructorCheck is a helper class that helps to detect if a tracked object * was deleted. * This is useful for objects that request callbacks from other components. * * Classes needing this functionality should: * - derive from DestructorCheck * * Callback context can be extended with an instance of DestructorCheck::Safety * object initialized with a reference to the object dereferenced from the * callback. Once the callback is invoked, it can use this safety object to * check if the object was not deallocated yet before dereferencing it. * * DestructorCheck does not perform any locking. It is intended to be used * only from a single thread. * * Example: * * class AsyncFoo : public DestructorCheck { * public: * ~AsyncFoo(); * // awesome async code with circuitous deletion paths * void async1(); * void async2(); * }; * * righteousFunc(AsyncFoo& f) { * DestructorCheck::Safety safety(f); * * f.async1(); // might have deleted f, oh noes * if (!safety.destroyed()) { * // phew, still there * f.async2(); * } * } */ class DestructorCheck { … }; } // namespace folly