Be smarter about clearing the weakref lists for instances, instance methods,
and functions: we only need to call PyObject_ClearWeakRefs() if the weakref list is non-NULL. Since these objects are common but weakrefs are still unusual, saving the call at deallocation time makes a lot of sense.
This commit is contained in:
parent
7408da54e2
commit
c916f5a390
|
@ -585,7 +585,8 @@ instance_dealloc(register PyInstanceObject *inst)
|
|||
extern long _Py_RefTotal;
|
||||
#endif
|
||||
_PyObject_GC_UNTRACK(inst);
|
||||
PyObject_ClearWeakRefs((PyObject *) inst);
|
||||
if (inst->in_weakreflist != NULL)
|
||||
PyObject_ClearWeakRefs((PyObject *) inst);
|
||||
|
||||
/* Temporarily resurrect the object. */
|
||||
#ifdef Py_TRACE_REFS
|
||||
|
@ -2071,7 +2072,8 @@ static void
|
|||
instancemethod_dealloc(register PyMethodObject *im)
|
||||
{
|
||||
_PyObject_GC_UNTRACK(im);
|
||||
PyObject_ClearWeakRefs((PyObject *)im);
|
||||
if (im->im_weakreflist != NULL)
|
||||
PyObject_ClearWeakRefs((PyObject *)im);
|
||||
Py_DECREF(im->im_func);
|
||||
Py_XDECREF(im->im_self);
|
||||
Py_XDECREF(im->im_class);
|
||||
|
|
|
@ -270,7 +270,8 @@ static void
|
|||
func_dealloc(PyFunctionObject *op)
|
||||
{
|
||||
_PyObject_GC_UNTRACK(op);
|
||||
PyObject_ClearWeakRefs((PyObject *) op);
|
||||
if (op->func_weakreflist != NULL)
|
||||
PyObject_ClearWeakRefs((PyObject *) op);
|
||||
Py_DECREF(op->func_code);
|
||||
Py_DECREF(op->func_globals);
|
||||
Py_DECREF(op->func_name);
|
||||
|
|
Loading…
Reference in New Issue