Слабкі довідкові об’єкти

Python підтримує слабкі посилання як об’єкти першого класу. Існує два типи об’єктів, які безпосередньо реалізують слабкі посилання. Перший є простим довідковим об’єктом, а другий діє як проксі для оригінального об’єкта, наскільки це можливо.

int PyWeakref_Check(PyObject *ob)

Повертає true, якщо ob є посиланням або проксі-об’єктом. Ця функція завжди успішна.

int PyWeakref_CheckRef(PyObject *ob)

Повертає true, якщо ob є посиланням на об’єкт. Ця функція завжди успішна.

int PyWeakref_CheckProxy(PyObject *ob)

Повертає true, якщо ob є проксі-об’єктом. Ця функція завжди успішна.

PyObject *PyWeakref_NewRef(PyObject *ob, PyObject *callback)
Return value: New reference. Part of the Stable ABI.

Return a weak reference object for the object ob. This will always return a new reference, but is not guaranteed to create a new object; an existing reference object may be returned. The second parameter, callback, can be a callable object that receives notification when ob is garbage collected; it should accept a single parameter, which will be the weak reference object itself. callback may also be None or NULL. If ob is not a weakly referencable object, or if callback is not callable, None, or NULL, this will return NULL and raise TypeError.

PyObject *PyWeakref_NewProxy(PyObject *ob, PyObject *callback)
Return value: New reference. Part of the Stable ABI.

Return a weak reference proxy object for the object ob. This will always return a new reference, but is not guaranteed to create a new object; an existing proxy object may be returned. The second parameter, callback, can be a callable object that receives notification when ob is garbage collected; it should accept a single parameter, which will be the weak reference object itself. callback may also be None or NULL. If ob is not a weakly referencable object, or if callback is not callable, None, or NULL, this will return NULL and raise TypeError.

PyObject *PyWeakref_GetObject(PyObject *ref)
Return value: Borrowed reference. Part of the Stable ABI.

Return the referenced object from a weak reference, ref. If the referent is no longer live, returns Py_None.

Примітка

Ця функція повертає borrowed reference на об’єкт, на який посилається. Це означає, що ви завжди повинні викликати Py_INCREF() для об’єкта, за винятком випадків, коли його не можна знищити перед останнім використанням запозиченого посилання.

PyObject *PyWeakref_GET_OBJECT(PyObject *ref)
Return value: Borrowed reference.

Similar to PyWeakref_GetObject(), but does no error checking.

void PyObject_ClearWeakRefs(PyObject *object)
Part of the Stable ABI.

This function is called by the tp_dealloc handler to clear weak references.

This iterates through the weak references for object and calls callbacks for those references which have one. It returns when all callbacks have been attempted.