There are a few functions specific to Python functions.
The C structure used for functions.
This is an instance of
PyTypeObject
and represents the Python function type. It is exposed to Python programmers as
types.FunctionType
.
返回 True 若
o
is a function object (has type
PyFunction_Type
). The parameter must not be
NULL
. This function always succeeds.
Return a new function object associated with the code object code . globals must be a dictionary with the global variables accessible to the function.
The function’s docstring and name are retrieved from the code object.
__module__
检索自
globals
. The argument defaults, annotations and closure are set to
NULL
.
__qualname__
is set to the same value as the code object’s
co_qualname
字段。
As
PyFunction_New()
, but also allows setting the function object’s
__qualname__
属性。
qualname
should be a unicode object or
NULL
;若
NULL
,
__qualname__
attribute is set to the same value as the code object’s
co_qualname
字段。
Added in version 3.3.
Return the code object associated with the function object op .
Return the globals dictionary associated with the function object op .
返回
借位引用
到
__module__
属性在
function object
op
. It can be
NULL
.
This is normally a
string
containing the module name, but can be set to any other object by Python code.
Return the argument default values of the function object
op
. This can be a tuple of arguments or
NULL
.
Set the argument default values for the function object
op
.
defaults
必须为
Py_None
or a tuple.
引发
SystemError
并返回
-1
当故障时。
Set the vectorcall field of a given function object func .
Warning: extensions using this API must preserve the behavior of the unaltered (default) vectorcall function!
3.12 版添加。
Return the closure associated with the function object
op
. This can be
NULL
or a tuple of cell objects.
Set the closure associated with the function object
op
.
closure
必须为
Py_None
or a tuple of cell objects.
引发
SystemError
并返回
-1
当故障时。
Return the annotations of the function object
op
. This can be a mutable dictionary or
NULL
.
Set the annotations for the function object
op
.
annotations
must be a dictionary or
Py_None
.
引发
SystemError
并返回
-1
当故障时。
注册
callback
as a function watcher for the current interpreter. Return an ID which may be passed to
PyFunction_ClearWatcher()
. In case of error (e.g. no more watcher IDs available), return
-1
and set an exception.
3.12 版添加。
Clear watcher identified by
watcher_id
previously returned from
PyFunction_AddWatcher()
for the current interpreter. Return
0
当成功时,或
-1
and set an exception on error (e.g. if the given
watcher_id
was never registered.)
3.12 版添加。
Enumeration of possible function watcher events: -
PyFunction_EVENT_CREATE
-
PyFunction_EVENT_DESTROY
-
PyFunction_EVENT_MODIFY_CODE
-
PyFunction_EVENT_MODIFY_DEFAULTS
-
PyFunction_EVENT_MODIFY_KWDEFAULTS
3.12 版添加。
Type of a function watcher callback function.
若
event
is
PyFunction_EVENT_CREATE
or
PyFunction_EVENT_DESTROY
then
new_value
将是
NULL
。否则,
new_value
will hold a
借位引用
to the new value that is about to be stored in
func
for the attribute that is being modified.
The callback may inspect but must not modify func ; doing so could have unpredictable effects, including infinite recursion.
若
event
is
PyFunction_EVENT_CREATE
, then the callback is invoked after
func
has been fully initialized. Otherwise, the callback is invoked before the modification to
func
takes place, so the prior state of
func
can be inspected. The runtime is permitted to optimize away the creation of function objects when possible. In such cases no event will be emitted. Although this creates the possibility of an observable difference of runtime behavior depending on optimization decisions, it does not change the semantics of the Python code being executed.
若
event
is
PyFunction_EVENT_DESTROY
, Taking a reference in the callback to the about-to-be-destroyed function will resurrect it, preventing it from being freed at this time. When the resurrected object is destroyed later, any watcher callbacks active at that time will be called again.
If the callback sets an exception, it must return
-1
; this exception will be printed as an unraisable exception using
PyErr_WriteUnraisable()
. Otherwise it should return
0
.
There may already be a pending exception set on entry to the callback. In this case, the callback should return
0
with the same exception still set. This means the callback may not call any other API that can set an exception unless it saves and clears the exception state first, and restores it before returning.
3.12 版添加。