"sys" --- 系统相关的形参和函数
******************************

======================================================================

该模块提供了一些变量和函数。这些变量可能被解释器使用，也可能由解释器提
供。这些函数会影响解释器。本模块总是可用的。

sys.abiflags

   在POSIX系统上，以标准的 "configure" 脚本构建的 Python 中，这个变量
   会包含 **PEP 3149** 中定义的ABI标签。

   在 3.2 版本加入.

   在 3.8 版本发生变更: 默认的 flags 变为了空字符串（用于 pymalloc 的
   "m" 旗标已经移除）

   可用性: Unix。

sys.addaudithook(hook)

   将可调用的对象 *hook* 附加到当前（子）解释器的活动的审计钩子列表中
   。

   当通过 "sys.audit()" 函数引发审计事件时，每个钩子将按照其被加入的先
   后顺序被调用，调用时会传入事件名称和参数元组。 由
   "PySys_AddAuditHook()" 添加的原生钩子会先被调用，然后是当前（子）解
   释器中添加的钩子。 接下来这些钩子会记录事件，引发异常来中止操作，或
   是完全终止进程。

   请注意审计钩子主要是用于收集有关内部或在其他情况下不可观察操作的信
   息，可能是通过 Python 或者用 Python 编写的库。 它们不适合用于实现“
   沙盒”。 特别重要的一点是，恶意代码可以轻易地禁用或绕过使用此函数添
   加的钩子。 至少，在初始化运行时之前必须使用 C API
   "PySys_AddAuditHook()" 来添加任何安全敏感的钩子，并且应当完全删除或
   密切监视任何允许任意修改内存的模块 (如 "ctypes")。

   调用 "sys.addaudithook()" 时它自身将引发一个名为 "sys.addaudithook"
   的审计事件且不附带参数。 如果任何现有的钩子引发了派生自
   "RuntimeError" 的异常，则新的钩子不会被添加并且该异常会被抑制。 其
   结果就是，调用者无法确保他们的钩子已经被添加，除非他们控制了全部现
   有的钩子。

   请参阅 审计事件表 以获取由 CPython 引发的所有事件，并参阅 **PEP
   578** 了解最初的设计讨论。

   在 3.8 版本加入.

   在 3.8.1 版本发生变更: 派生自 "Exception" （而非 "RuntimeError" ）
   的异常不会被抑制。

   **CPython 实现细节：** 启用跟踪时（参阅 "settrace()" ），仅当可调用
   对象（钩子）的 "__cantrace__" 成员设置为 true 时，才会跟踪该钩子。
   否则，跟踪功能将跳过该钩子。

sys.argv

   一个列表，其中包含了被传递给 Python 脚本的命令行参数。 "argv[0]" 为
   脚本的名称（是否是完整的路径名取决于操作系统）。如果是通过 Python
   解释器的命令行参数 "-c" 来执行的， "argv[0]" 会被设置成字符串
   "'-c'" 。如果没有脚本名被传递给 Python 解释器， "argv[0]" 为空字符
   串。

   为了遍历标准输入，或者通过命令行传递的文件列表，参照 "fileinput" 模
   块

   另请参阅 "sys.orig_argv"。

   备注:

     在 Unix 上，系统传递的命令行参数是字节类型的。Python 使用文件系统
     编码和 "surrogateescape" 错误处理方案对它们进行解码。当需要原始字
     节时，可以通过 "[os.fsencode(arg) for arg in sys.argv]" 来获取。

sys.audit(event, *args)

   引发一个审计事件并触发任何激活的审计钩子。 *event* 是一个用于标识事
   件的字符串，*args* 会包含有关事件的更多信息的可选参数。 特定事件的
   参数的数量和类型会被视为是公有的稳定 API 且不应当在版本之间进行修改
   。

   例如，有一个审计事件的名称为 "os.chdir"。 此事件具有一个名为 *path*
   的参数，该参数将包含所请求的新工作目录。

   "sys.audit()" 将调用现有的审计钩子，传入事件名称和参数，并将重新引
   发来自任何钩子的第一个异常。 通常来说，如果有一个异常被引发，则它不
   应当被处理且其进程应当被尽可能快地终止。 这将允许钩子实现来决定对特
   定事件要如何反应：它们可以只是将事件写入日志或是通过引发异常来中止
   操作。

   钩子程序由 "sys.addaudithook()" 或 "PySys_AddAuditHook()" 函数添加
   。

   与本函数相等效的原生函数是 "PySys_Audit()"，应尽量使用原生函数。

   参阅 审计事件表 以获取 CPython 定义的所有审计事件。

   在 3.8 版本加入.

sys.base_exec_prefix

   在 "site.py" 运行之前， Python 启动的时候被设置为跟 "exec_prefix"
   同样的值。如果不是运行在 虚拟环境 中，两个值会保持相同；如果
   "site.py" 发现处于一个虚拟环境中， "prefix" 和 "exec_prefix" 将会指
   向虚拟环境。然而 "base_prefix" 和 "base_exec_prefix" 将仍然会指向基
   础的 Python 环境（用来创建虚拟环境的 Python 环境）

   在 3.3 版本加入.

sys.base_prefix

   在 "site.py" 运行之前， Python 启动的时候被设置为跟 "prefix" 同样的
   值。如果不是运行在 虚拟环境 中, 两个值会保持相同；如果 "site.py" 发
   现处于一个虚拟环境中， "prefix" 和 "exec_prefix" 将会指向虚拟环境。
   然而 "base_prefix" 和 "base_exec_prefix" 将仍然会指向基础的 Python
   环境（用来创建虚拟环境的 Python 环境）

   在 3.3 版本加入.

sys.byteorder

   本地字节顺序的指示符。在大端序（最高有效位优先）操作系统上值为
   "'big'" ，在小端序（最低有效位优先）操作系统上为 "'little'" 。

sys.builtin_module_names

   一个包含所有被编译进 Python 解释器的模块的名称的字符串元组。 （此信
   息无法通过任何其他办法获取 --- "modules.keys()" 仅会列出导入的模块
   。）

   另请参阅 "sys.stdlib_module_names" 列表。

sys.call_tracing(func, args)

   当启用跟踪时，调用 "func(*args)"。 跟踪状态将被保存，并在以后恢复。
   这被设计为由调试器从某个检查点执行调用，以便递归地调试或分析某些其
   他代码。

   在调用由 "settrace()" 或 "setprofile()" 设置的跟踪函数时跟踪将暂停
   以避免无限递归。 "call_tracing()" 会启用跟踪函数的显式递归。

sys.copyright

   一个字符串，包含了 Python 解释器有关的版权信息

sys._clear_type_cache()

   清除内部的类型缓存。类型缓存是为了加速查找方法和属性的。在调试引用
   泄漏的时候调用这个函数 *只会* 清除不必要的引用。

   这个函数应该只在内部为了一些特定的目的使用。

sys._current_frames()

   返回一个字典，存放着每个线程的标识符与（调用本函数时）该线程栈顶的
   帧（当前活动的帧）之间的映射。注意 "traceback" 模块中的函数可以在给
   定某一帧的情况下构建调用堆栈。

   这对于调试死锁最有用：本函数不需要死锁线程的配合，并且只要这些线程
   的调用栈保持死锁，它们就是冻结的。在调用本代码来检查栈顶的帧的那一
   刻，非死锁线程返回的帧可能与该线程当前活动的帧没有任何关系。

   这个函数应该只在内部为了一些特定的目的使用。

   引发一个 审计事件 "sys._current_frames"，没有附带参数。

sys._current_exceptions()

   返回一个字典，存放着每个线程的标识与调用此函数时该线程当前活动帧的
   栈顶异常之间的映射。 如果某个线程当前未在处理异常，它将不被包括在结
   果字典中。

   这对于静态性能分析来说最为有用。

   这个函数应该只在内部为了一些特定的目的使用。

   引发一个 审计事件 "sys._current_exceptions"，不附带任何参数。

   在 3.12 版本发生变更: 现在字典中的每个值都是单独的异常实例，而不是
   如 "sys.exc_info()" 所返回的 3 元组。

sys.breakpointhook()

   本钩子函数由内建函数 "breakpoint()" 调用。默认情况下，它将进入
   "pdb" 调试器，但可以将其改为任何其他函数，以选择使用哪个调试器。

   该函数的特征取决于其调用的函数。例如，默认绑定（即
   "pdb.set_trace()" ）不要求提供参数，但可以将绑定换成要求提供附加参
   数（位置参数/关键字参数）的函数。内建函数 "breakpoint()" 直接将其
   "*args" 和 "**kws" 传入。"breakpointhooks()" 返回的所有内容都会从
   "breakpoint()" 返回。

   默认的实现首先会查询环境变量 "PYTHONBREAKPOINT"。如果将该变量设置为
   ""0""，则本函数立即返回，表示在断点处无操作。如果未设置该环境变量或
   将其设置为空字符串，则调用 "pdb.set_trace()"。否则，此变量应指定要
   运行的函数，指定函数时应使用 Python 的点导入命名法，如
   "package.subpackage.module.function"。这种情况下将导入
   "package.subpackage.module"，且导入的模块必须有一个名为
   "function()" 的可调用对象。该可调用对象会运行，"*args" 和 "**kws"
   会传入，且无论 "function()" 返回什么，"sys.breakpointhook()" 都将返
   回到內建函数 "breakpoint()"。

   请注意，如果在导入 "PYTHONBREAKPOINT" 指定的可调用对象时出错，则将
   报告一个 "RuntimeWarning" 并忽略断点。

   另请注意，如果以编程方式覆盖 "sys.breakpointhook()"，则 *不会* 查询
   "PYTHONBREAKPOINT"。

   在 3.7 版本加入.

sys._debugmallocstats()

   将有关 CPython 内存分配器状态的底层的信息打印至 stderr。

   如果 Python 是 以调试模式编译的 ("使用 --with-pydebug 配置选项")，
   它还会执行某些高开销的内部一致性检查。

   在 3.3 版本加入.

   **CPython 实现细节：** 本函数仅限 CPython。此处没有定义确切的输出格
   式，且可能会更改。

sys.dllhandle

   指向 Python DLL 句柄的整数。

   可用性: Windows。

sys.displayhook(value)

   如果 *value* 不是 "None"，则本函数会将 "repr(value)" 打印至
   "sys.stdout"，并将 *value* 保存在 "builtins._" 中。如果
   "repr(value)" 无法用 "sys.stdout.errors" 错误处理方案（可能为
   "'strict'" ）编码为 "sys.stdout.encoding"，则用
   "'backslashreplace'" 错误处理方案将其编码为 "sys.stdout.encoding"。

   在交互式 Python 会话中运行 *expression* 产生结果后，将在结果上调用
   "sys.displayhook"。若要自定义这些 value 的显示，可以将
   "sys.displayhook" 指定为另一个单参数函数。

   伪代码:

      def displayhook(value):
          if value is None:
              return
          # Set '_' to None to avoid recursion
          builtins._ = None
          text = repr(value)
          try:
              sys.stdout.write(text)
          except UnicodeEncodeError:
              bytes = text.encode(sys.stdout.encoding, 'backslashreplace')
              if hasattr(sys.stdout, 'buffer'):
                  sys.stdout.buffer.write(bytes)
              else:
                  text = bytes.decode(sys.stdout.encoding, 'strict')
                  sys.stdout.write(text)
          sys.stdout.write("\n")
          builtins._ = value

   在 3.2 版本发生变更: 在发生 "UnicodeEncodeError" 时使用
   "'backslashreplace'" 错误处理方案。

sys.dont_write_bytecode

   如果该值为 true，则 Python 在导入源码模块时将不会尝试写入 ".pyc" 文
   件。该值会被初始化为 "True" 或 "False"，依据是 "-B" 命令行选项和
   "PYTHONDONTWRITEBYTECODE" 环境变量，可以自行设置该值，来控制是否生
   成字节码文件。

sys._emscripten_info

   这个 *named tuple* 保存了 *wasm32-emscripten* 平台中环境的相关信息
   。 该命名元组处于暂定状态并可能在将来被更改。

   _emscripten_info.emscripten_version

      以整数元组 (major, minor, micro) 表示的 Emscripten 版本，例如
      "(3, 1, 8)"。

   _emscripten_info.runtime

      运行时字符串，例如 browser user agent, "'Node.js v14.18.2'" 或
      "'UNKNOWN'"。

   _emscripten_info.pthreads

      如果 Python 编译附带了 Emscripten pthreads 支持则为 "True"。

   _emscripten_info.shared_memory

      如果 Python 编译附带了共享内存支持则为 "True"。

   可用性: Emscripten。

   在 3.11 版本加入.

sys.pycache_prefix

   如果设置了该值 (不能为 "None")，Python 会将字节码缓存文件 ".pyc" 写
   入到以该值指定的目录为根的并行目录树中（并从中读取），而不是在源代
   码树的 "__pycache__" 目录下读写。 源代码树中所有的 "__pycache__" 目
   录都将被忽略并且新的 ".pyc" 文件将被写入到 pycache 前缀指定的位置。
   因此如果你使用 "compileall" 作为预编译步骤，你必须确保使用与在运行
   时相同的 pycache 前缀（如果有的话）来运行它。

   相对路径将解释为相对于当前工作目录。

   该值的初值设置，依据 "-X" "pycache_prefix=PATH" 命令行选项或
   "PYTHONPYCACHEPREFIX" 环境变量的值（命令行优先）。如果两者均未设置
   ，则为 "None"。

   在 3.8 版本加入.

sys.excepthook(type, value, traceback)

   本函数会将所给的回溯和异常输出到 "sys.stderr" 中。

   当有 "SystemExit" 以外的异常被引发且未被捕获时，解释器会调用
   "sys.excepthook" 并附带三个参数：异常类、异常实例和回溯对象。 在交
   互会话中这将发生在控制返回提示符之前；在 Python 程序中这将发生在程
   序退出之前。 这种最高层级异常的处理可以通过为 "sys.excepthook" 指定
   另一个三参数函数来实现自定义。

   引发一个 审计事件 "sys.excepthook"，附带参数 "hook", "type",
   "value", "traceback"。

   参见:

     "sys.unraisablehook()" 函数处理无法抛出的异常，
     "threading.excepthook()" 函数处理 "threading.Thread.run()" 抛出的
     异常。

sys.__breakpointhook__
sys.__displayhook__
sys.__excepthook__
sys.__unraisablehook__

   程序开始时，这些对象存有 "breakpointhook"、"displayhook"、
   "excepthook" 和 "unraisablehook" 的初始值。保存它们是为了可以在
   "breakpointhook"、"displayhook" 和 "excepthook"、"unraisablehook"
   被破坏或被替换时恢复它们。

   在 3.7 版本加入: __breakpointhook__

   在 3.8 版本加入: __unraisablehook__

sys.exception()

   当此函数在某个异常处理句柄执行过程中（如 "except" 或 "except*" 子句
   ）被调用时，将返回被该处理句柄所捕获的异常实例。 当有多个异常处理句
   柄彼此嵌套时，只有最内层处理句柄所处理的异常可以被访问到。

   如果没有任何异常处理句柄在执行，此函数将返回 "None"。

   在 3.11 版本加入.

sys.exc_info()

   此函数返回被处理异常的旧式表示形式。 如果异常 "e" 当前已被处理 (因
   此 "exception()" 将会返回 "e")，则 "exc_info()" 将返回元组
   "(type(e), e, e.__traceback__)"。 也就是说，包含该异常类型
   ("BaseException" 的子类) 的元组，异常本身，以及一个通常封装了异常最
   后发生位置上调用栈的 回溯对象。

   如果堆栈上的任何地方都没有处理异常，则此函数将返回一个包含三个
   "None" 的元组。

   在 3.11 版本发生变更: "type" 和 "traceback" 字段现在是派生自
   "value" (异常实例)，因此当一个异常在处理期间被修改时，其变化会在后
   续对 "exc_info()" 的调用结果中反映出来。

sys.exec_prefix

   一个字符串，提供特定域的目录前缀，该目录中安装了与平台相关的 Python
   文件，默认也是 "'/usr/local'"。该目录前缀可以在构建时使用
   **configure** 脚本的 "--exec-prefix" 参数进行设置。具体而言，所有配
   置文件（如 "pyconfig.h" 头文件）都安装在目录
   "*exec_prefix*/lib/python*X.Y*/config" 中，共享库模块安装在
   "*exec_prefix*/lib/python*X.Y*/lib-dynload" 中，其中 *X.Y* 是
   Python 的版本号，如 "3.2"。

   备注:

     如果在一个 虚拟环境 中，那么该值将在 "site.py" 中被修改，指向虚拟
     环境。Python 安装位置仍然可以用 "base_exec_prefix" 来获取。

sys.executable

   一个字符串，提供 Python 解释器的可执行二进制文件的绝对路径，仅在部
   分系统中此值有意义。如果 Python 无法获取其可执行文件的真实路径，则
   "sys.executable" 将为空字符串或 "None"。

sys.exit([arg])

   引发一个 "SystemExit" 异常，表示打算退出解释器。

   可选参数 *arg* 可以是表示退出状态的整数（默认为 0），也可以是其他类
   型的对象。如果它是整数，则 shell 等将 0 视为“成功终止”，非零值视为“
   异常终止”。大多数系统要求该值的范围是 0--127，否则会产生不确定的结
   果。某些系统为退出代码约定了特定的含义，但通常尚不完善；Unix 程序通
   常用 2 表示命令行语法错误，用 1 表示所有其他类型的错误。传入其他类
   型的对象，如果传入 "None" 等同于传入 0，如果传入其他对象则将其打印
   至 "stderr"，且退出代码为 1。特别地，"sys.exit("some error
   message")" 可以在发生错误时快速退出程序。

   由于 "exit()" 最终 "只" 引发了一个异常，它只在从主线程调用时退出进
   程，而异常不会被拦截。 "try" 语句的 finally 子句所指定的清理动作会
   被遵守，并且有可能在外层拦截退出的尝试。

   在 3.6 版本发生变更: 在 Python 解释器捕获 "SystemExit" 后，如果在清
   理中发生错误（如清除标准流中的缓冲数据时出错），则退出状态码将变为
   120。

sys.flags

   *具名元组* *flags* 含有命令行标志的状态。这些属性是只读的。

   +----------------------------------------------------+----------------------------------------------------+
   | flags.debug                                        | "-d"                                               |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.inspect                                      | "-i"                                               |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.interactive                                  | "-i"                                               |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.isolated                                     | "-I"                                               |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.optimize                                     | "-O" 或 "-OO"                                      |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.dont_write_bytecode                          | "-B"                                               |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.no_user_site                                 | "-s"                                               |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.no_site                                      | "-S"                                               |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.ignore_environment                           | "-E"                                               |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.verbose                                      | "-v"                                               |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.bytes_warning                                | "-b"                                               |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.quiet                                        | "-q"                                               |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.hash_randomization                           | "-R"                                               |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.dev_mode                                     | "-X dev" (Python 开发模式)                         |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.utf8_mode                                    | "-X utf8"                                          |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.safe_path                                    | "-P"                                               |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.int_max_str_digits                           | "-X int_max_str_digits" (integer string conversion |
   |                                                    | length limitation)                                 |
   +----------------------------------------------------+----------------------------------------------------+
   | flags.warn_default_encoding                        | "-X warn_default_encoding"                         |
   +----------------------------------------------------+----------------------------------------------------+

   在 3.2 版本发生变更: 为新的 "-q" 标志添加了 "quiet" 属性

   在 3.2.3 版本加入: "hash_randomization" 属性

   在 3.3 版本发生变更: 删除了过时的 "division_warning" 属性

   在 3.4 版本发生变更: 为 "-I" "isolated" 标志添加了 "isolated" 属性
   。

   在 3.7 版本发生变更: 为新的 Python 开发模式 添加了 "dev_mode" 属性
   ，为新的 "-X" "utf8" 标志添加了 "utf8_mode" 属性。

   在 3.10 版本发生变更: 为 "-X" "warn_default_encoding" 旗标添加了
   "warn_default_encoding" 属性。

   在 3.11 版本发生变更: 添加了用于 "-P" 选项的 "safe_path" 属性。

   在 3.11 版本发生变更: 增加了 "int_max_str_digits" 属性。

sys.float_info

   一个 *具名元组*，存有浮点型的相关信息。它包含的是关于精度和内部表示
   的底层信息。这些值与标准头文件 "float.h" 中为 C 语言定义的各种浮点
   常量对应，详情请参阅 1999 ISO/IEC C 标准 [C99] 的 5.2.4.2.2 节，
   'Characteristics of floating types（浮点型的特性）'。


   "float_info" *named tuple* 的属性
   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

   +-----------------------------------+-----------------------------------+-----------------------------------+
   | attribute -- 属性                 | float.h 宏                        | 说明                              |
   |===================================|===================================|===================================|
   | float_info.epsilon                | "DBL_EPSILON"                     | 1.0 与可表示为浮点数的大于 1.0 的 |
   |                                   |                                   | 最小值之间的差。  另请参阅        |
   |                                   |                                   | "math.ulp()"。                    |
   +-----------------------------------+-----------------------------------+-----------------------------------+
   | float_info.dig                    | "DBL_DIG"                         | 浮点数可以真实表示的十进制数的最  |
   |                                   |                                   | 大位数；见下文。                  |
   +-----------------------------------+-----------------------------------+-----------------------------------+
   | float_info.mant_dig               | "DBL_MANT_DIG"                    | 浮点数精度：以 "radix" 为基数浮点 |
   |                                   |                                   | 数的有效位数。                    |
   +-----------------------------------+-----------------------------------+-----------------------------------+
   | float_info.max                    | "DBL_MAX"                         | 可表示的最大正有限浮点数。        |
   +-----------------------------------+-----------------------------------+-----------------------------------+
   | float_info.max_exp                | "DBL_MAX_EXP"                     | 使得 "radix**(e-1)" 是可表示的有  |
   |                                   |                                   | 限浮点数的最大整数 *e*。          |
   +-----------------------------------+-----------------------------------+-----------------------------------+
   | float_info.max_10_exp             | "DBL_MAX_10_EXP"                  | 使得 "10**e" 在可表示的有限浮点数 |
   |                                   |                                   | 范围内的最大整数 *e*。            |
   +-----------------------------------+-----------------------------------+-----------------------------------+
   | float_info.min                    | "DBL_MIN"                         | 可表示的最小正 *规范化* 浮点数。  |
   |                                   |                                   | 使用 "math.ulp(0.0)" 获取可表示的 |
   |                                   |                                   | 最小正 *非规格化* 浮点数          |
   +-----------------------------------+-----------------------------------+-----------------------------------+
   | float_info.min_exp                | "DBL_MIN_EXP"                     | 使得 "radix**(e-1)" 是规范化浮点  |
   |                                   |                                   | 数的最小整数 *e*。                |
   +-----------------------------------+-----------------------------------+-----------------------------------+
   | float_info.min_10_exp             | "DBL_MIN_10_EXP"                  | 使得 "10**e" 是归范化浮点数的最小 |
   |                                   |                                   | 整数 *e*。                        |
   +-----------------------------------+-----------------------------------+-----------------------------------+
   | float_info.radix                  | "FLT_RADIX"                       | 指数表示法中采用的基数。          |
   +-----------------------------------+-----------------------------------+-----------------------------------+
   | float_info.rounds                 | "FLT_ROUNDS"                      | 一个代表浮点运算舍入模式的整数。  |
   |                                   |                                   | 它反映了解释器启动时系统          |
   |                                   |                                   | "FLT_ROUNDS" 宏的值：  * "-1": 不 |
   |                                   |                                   | 确定  * "0": 向零值  * "1": 向最  |
   |                                   |                                   | 近值  * "2": 向正无穷  * "3": 向  |
   |                                   |                                   | 负无穷  "FLT_ROUNDS" 的所有其他值 |
   |                                   |                                   | 被用于代表具体实现所定义的舍入行  |
   |                                   |                                   | 为。                              |
   +-----------------------------------+-----------------------------------+-----------------------------------+

   属性 "sys.float_info.dig" 需要进一步的解释。 如果 "s" 是表示十进制
   数的字符串，且最多有 "sys.float_info.dig" 位有效数字，那么将 "s" 转
   换为浮点数再转换回来将恢复为一个表示相同十进制值的字符串:

      >>> import sys
      >>> sys.float_info.dig
      15
      >>> s = '3.14159265358979'    # decimal string with 15 significant digits
      >>> format(float(s), '.15g')  # convert to float and back -> same value
      '3.14159265358979'

   但是对于超过 "sys.float_info.dig" 位有效数字的字符串，转换前后并非
   总是相同:

      >>> s = '9876543211234567'    # 16 significant digits is too many!
      >>> format(float(s), '.16g')  # conversion changes value
      '9876543211234568'

sys.float_repr_style

   一个字符串，反映 "repr()" 函数在浮点数上的行为。如果该字符串是
   "'short'"，那么对于（非无穷的）浮点数 "x"，"repr(x)" 将会生成一个短
   字符串，满足 "float(repr(x)) == x" 的特性。这是 Python 3.1 及更高版
   本中的常见行为。否则 "float_repr_style" 的值将是 "'legacy'"，此时
   "repr(x)" 的行为方式将与 Python 3.1 之前的版本相同。

   在 3.1 版本加入.

sys.getallocatedblocks()

   返回解释器当前已分配的内存块数，无论它们大小如何。本函数主要用于跟
   踪和调试内存泄漏。因为解释器有内部缓存，所以不同调用之间结果会变化
   。可能需要调用 "_clear_type_cache()" 和 "gc.collect()" 使结果更容易
   预测。

   如果当前 Python 构建或实现无法合理地计算此信息，允许
   "getallocatedblocks()" 返回 0。

   在 3.4 版本加入.

sys.getunicodeinternedsize()

   返回已被处置的 unicode 对象数量。

   在 3.12 版本加入.

sys.getandroidapilevel()

   返回一个整数，表示 Android 构建时 API 版本。

   可用性：Android。

   在 3.7 版本加入.

sys.getdefaultencoding()

   返回当前 Unicode 实现所使用的默认字符串编码格式名称。

sys.getdlopenflags()

   返回用于 "dlopen()" 调用的旗标的当前值。 旗标值的符号名称可在 "os"
   模块中找到 ("RTLD_*xxx*" 常量，例如 "os.RTLD_LAZY")。

   可用性: Unix。

sys.getfilesystemencoding()

   获取 *文件系统编码格式*: 该编码格式与 *文件系统错误处理句柄* 一起使
   用以便在 Unicode 文件名和字节文件名之间进行转换。 文件系统错误处理
   句柄是从 "getfilesystemencodeerrors()" 返回的。

   为获得最佳兼容性，在任何时候都应使用 str 来表示文件名，尽管使用
   bytes 来表示文件名也是受支持的。 接受还返回文件名的函数应当支持 str
   或 bytes 并在内部将其转换为系统首选的表示形式。

   应使用 "os.fsencode()" 和 "os.fsdecode()" 来保证所采用的编码和错误
   处理方案都是正确的。

   *filesystem encoding and error handler* 是在 Python 启动时通过
   "PyConfig_Read()" 函数来配置的：请参阅 "PyConfig" 的
   "filesystem_encoding" 和 "filesystem_errors" 等成员。

   在 3.2 版本发生变更: "getfilesystemencoding()" 的结果将不再有可能是
   "None"。

   在 3.6 版本发生变更: Windows 不再保证会返回 "'mbcs'"。详情请参阅
   **PEP 529** 和 "_enablelegacywindowsfsencoding()"。

   在 3.7 版本发生变更: 返回 "'utf-8'"，如果启用了 Python UTF-8 模式
   的话。

sys.getfilesystemencodeerrors()

   获取 *文件系统错误处理句柄*: 该错误处理句柄与 *文件系统编码格式* 一
   起使用以便在 Unicode 文件名和字节文件名之间进程转换。 文件系统编码
   格式是由 "getfilesystemencoding()" 来返回的。

   应使用 "os.fsencode()" 和 "os.fsdecode()" 来保证所采用的编码和错误
   处理方案都是正确的。

   *filesystem encoding and error handler* 是在 Python 启动时通过
   "PyConfig_Read()" 函数来配置的：请参阅 "PyConfig" 的
   "filesystem_encoding" 和 "filesystem_errors" 等成员。

   在 3.6 版本加入.

sys.get_int_max_str_digits()

   返回 整数字符串转换长度限制 的当前值。 另请参阅
   "set_int_max_str_digits()"。

   在 3.11 版本加入.

sys.getrefcount(object)

   返回 *object* 的引用计数。返回的计数通常比预期的多一，因为它包括了
   作为 "getrefcount()" 参数的这一次（临时）引用。

   请注意返回的值可能并不真正反映对象的实际持有的引用数。 例如，有些对
   象是“永生”的并具有非常高的 refcount 值，这并不反映实际的引用数。 因
   此，除了 0 或 1 这两个值，不要依赖返回值的准确性。

   在 3.12 版本发生变更: 永生对象具有与对象的实际引用次数不相符的非常
   大的引用计数。

sys.getrecursionlimit()

   返回当前的递归限制值，即 Python 解释器堆栈的最大深度。此限制可防止
   无限递归导致的 C 堆栈溢出和 Python 崩溃。该值可以通过
   "setrecursionlimit()" 设置。

sys.getsizeof(object[, default])

   返回对象的大小（以字节为单位）。该对象可以是任何类型。所有内建对象
   返回的结果都是正确的，但对于第三方扩展不一定正确，因为这与具体实现
   有关。

   只计算直接分配给对象的内存消耗，不计算它所引用的对象的内存消耗。

   对象不提供计算大小的方法时，如果传入过 *default* 则返回它，否则抛出
   "TypeError" 异常。

   如果对象由垃圾回收器管理，则 "getsizeof()" 将调用对象的
   "__sizeof__" 方法，并在上层添加额外的垃圾回收器。

   请参阅 recursive sizeof recipe 查看一个递归使用 "getsizeof()" 来找
   出各个容器及其全部内容大小的示例。

sys.getswitchinterval()

   返回解释器的“线程切换间隔时间”，请参阅 "setswitchinterval()"。

   在 3.2 版本加入.

sys._getframe([depth])

   返回来自调用栈的一个帧对象。如果传入可选整数 *depth*，则返回从栈顶
   往下相应调用层数的帧对象。如果该数比调用栈更深，则抛出 "ValueError"
   。*depth* 的默认值是 0，返回调用栈顶部的帧。

   引发一个 审计事件 "sys._getframe"，附带参数 "frame"。

   **CPython 实现细节：** 这个函数应该只在内部为了一些特定的目的使用。
   不保证它在所有 Python 实现中都存在。

sys._getframemodulename([depth])

   从调用栈返回一个模块的名称。 如果给出了可选的整数 *depth*，则返回从
   栈顶往下相应调用层数的模块。 如果该数值比调用栈更深，或者如果该模块
   不可被标识，则返回 "None"。 *depth* 的默认值为零，即返回位于调用栈
   顶端的模块。

   引发一个 审计事件 "sys._getframemodulename"，附带参数 "depth"。

   **CPython 实现细节：** 这个函数应该只在内部为了一些特定的目的使用。
   不保证它在所有 Python 实现中都存在。

sys.getprofile()

   返回由 "setprofile()" 设置的性能分析函数。

sys.gettrace()

   返回由 "settrace()" 设置的跟踪函数。

   **CPython 实现细节：** "gettrace()" 函数仅用于实现调试器，性能分析
   器，打包工具等。它的行为是实现平台的一部分，而不是语言定义的一部分
   ，因此并非在所有 Python 实现中都可用。

sys.getwindowsversion()

   返回一个具名元组，描述当前正在运行的 Windows 版本。元素名称包括
   *major*, *minor*, *build*, *platform*, *service_pack*,
   *service_pack_minor*, *service_pack_major*, *suite_mask*,
   *product_type* 和 *platform_version*。*service_pack* 包含一个字符串
   ，*platform_version* 包含一个三元组，其他所有值都是整数。元素也可以
   通过名称来访问，所以 "sys.getwindowsversion()[0]" 与
   "sys.getwindowsversion().major" 是等效的。为保持与旧版本的兼容性，
   只有前 5 个元素可以用索引检索。

   *platform* 将为 "2" (VER_PLATFORM_WIN32_NT)。

   *product_type* 可能是以下值之一：

   +-----------------------------------------+-----------------------------------+
   | 常量                                    | 含意                              |
   |=========================================|===================================|
   | "1" (VER_NT_WORKSTATION)                | 系统是工作站。                    |
   +-----------------------------------------+-----------------------------------+
   | "2" (VER_NT_DOMAIN_CONTROLLER)          | 系统是域控制器。                  |
   +-----------------------------------------+-----------------------------------+
   | "3" (VER_NT_SERVER)                     | 系统是服务器，但不是域控制器。    |
   +-----------------------------------------+-----------------------------------+

   该函数包装了 Win32 "GetVersionEx()" 函数；有关这些字段的更多信息请
   参阅 "OSVERSIONINFOEX()" 的 Microsoft 文档。

   *platform_version* 返回当前操作系统的主要版本、次要版本和编译版本号
   ，而不是为该进程所模拟的版本。 它旨在用于日志记录而非特性检测。

   备注:

     *platform_version* 会从 kernel32.dll 获取版本号，这个版本可能与
     OS 版本不同。 请使用 "platform" 模块来获取准确的 OS 版本号。

   可用性: Windows。

   在 3.2 版本发生变更: 更改为具名元组，添加 *service_pack_minor*,
   *service_pack_major*, *suite_mask* 和 *product_type*。

   在 3.6 版本发生变更: 添加了 *platform_version*

sys.get_asyncgen_hooks()

   返回一个 *asyncgen_hooks* 对象，该对象类似于 "(firstiter,
   finalizer)" 形式的 "namedtuple"，其中 *firstiter* 和 *finalizer* 应
   为 "None" 或是一个接受 *asynchronous generator iterator* 作为参数的
   函数，并被用来在事件循环中调度异步生成器的最终化。

   在 3.6 版本加入: 详情请参阅 **PEP 525**。

   备注:

     本函数已添加至暂定软件包（详情请参阅 **PEP 411** ）。

sys.get_coroutine_origin_tracking_depth()

   获取由 "set_coroutine_origin_tracking_depth()" 设置的协程来源的追踪
   深度。

   在 3.7 版本加入.

   备注:

     本函数已添加至暂定软件包（详情请参阅 **PEP 411** ）。仅将其用于调
     试目的。

sys.hash_info

   一个 *具名元组*，给出数字类型的哈希的实现参数。关于数字类型的哈希的
   详情请参阅 数字类型的哈希运算。

   hash_info.width

      用于哈希值的位宽度

   hash_info.modulus

      用于数字哈案方案的质数模数 P

   hash_info.inf

      为正无穷大返回的哈希值

   hash_info.nan

      （该属性已不再被使用）

   hash_info.imag

      用于复数虚部的乘数

   hash_info.algorithm

      对字符串、字节串和内存视图进行哈希的算法名称

   hash_info.hash_bits

      哈希算法的内部输出大小

   hash_info.seed_bits

      哈希算法种子密钥的大小

   在 3.2 版本加入.

   在 3.4 版本发生变更: 添加了 *algorithm*, *hash_bits* 和 *seed_bits*

sys.hexversion

   编码为单个整数的版本号。该整数会确保每个版本都自增，其中适当包括了
   未发布版本。举例来说，要测试 Python 解释器的版本不低于 1.5.2，请使
   用:

      if sys.hexversion >= 0x010502F0:
          # use some advanced feature
          ...
      else:
          # use an alternative implementation or warn the user
          ...

   之所以称它为 "hexversion"，是因为只有将它传入内置函数 "hex()" 后，
   其结果才看起来有意义。也可以使用 *具名元组* "sys.version_info"，它
   对相同信息有着更人性化的编码。

   关于 "hexversion" 的更多信息可以在 API 和 ABI 版本管理 中找到。

sys.implementation

   一个对象，该对象包含当前运行的 Python 解释器的实现信息。所有 Python
   实现中都必须存在下列属性。

   *name* 是当前实现的标识符，如 "'cpython'"。实际的字符串由 Python 实
   现定义，但保证是小写字母。

   *version* 是一个具名元组，格式与 "sys.version_info" 相同。它表示
   Python *实现* 的版本。 另一个（由 "sys.version_info" 表示）是当前解
   释器遵循的相应 Python *语言* 的版本，两者具有不同的含义。 例如，对
   于 PyPy 1.8，"sys.implementation.version" 可能是
   "sys.version_info(1, 8, 0, 'final', 0)"，而 "sys.version_info" 则是
   "sys.version_info(2, 7, 2, 'final', 0)"。对于 CPython 而言两个值是
   相同的，因为它是参考实现。

   *hexversion* 是十六进制的实现版本，类似于 "sys.hexversion"。

   *cache_tag* 是导入机制使用的标记，用于已缓存模块的文件名。按照惯例
   ，它将由实现的名称和版本组成，如 "'cpython-33'"。但如果合适，Python
   实现可以使用其他值。如果 "cache_tag" 被置为 "None"，表示模块缓存已
   禁用。

   "sys.implementation" 可能包含相应 Python 实现的其他属性。这些非标准
   属性必须以下划线开头，此处不详细阐述。无论其内容如何，
   "sys.implementation" 在解释器运行期间或不同实现版本之间都不会更改。
   （但是不同 Python 语言版本间可能会不同。）详情请参阅 **PEP 421**。

   在 3.3 版本加入.

   备注:

     新的必要属性的添加必须经过常规的 PEP 过程。详情请参阅 **PEP 421**
     。

sys.int_info

   一个 *具名元组*，包含 Python 内部整数表示形式的信息。这些属性是只读
   的。

   int_info.bits_per_digit

      每个数位占用的比特位数。 Python 整数在内部以
      "2**int_info.bits_per_digit" 为基数存储。

   int_info.sizeof_digit

      用于表示一个数位的 C 类型的以字节为单位的大小。

   int_info.default_max_str_digits

      "sys.get_int_max_str_digits()" 在未被显式配置时所使用的默认值。

   int_info.str_digits_check_threshold

      "sys.set_int_max_str_digits()", "PYTHONINTMAXSTRDIGITS" 或 "-X
      int_max_str_digits" 的最小非零值。

   在 3.1 版本加入.

   在 3.11 版本发生变更: 添加了 "default_max_str_digits" 和
   "str_digits_check_threshold"。

sys.__interactivehook__

   当本属性存在，则以 交互模式 启动解释器时，将自动（不带参数地）调用
   本属性的值。该过程是在读取 "PYTHONSTARTUP" 文件之后完成的，所以可以
   在该文件中设置这一钩子。"site" 模块 设置了这一属性。

   引发一个 审计事件 "cpython.run_interactivehook"，附带参数 "hook"。

   在 3.4 版本加入.

sys.intern(string)

   将 *string* 插入 "interned" （驻留）字符串表，返回被插入的字符串 --
   它是 *string* 本身或副本。驻留字符串对提高字典查找的性能很有用 --
   如果字典中的键已驻留，且所查找的键也已驻留，则键（取散列后）的比较
   可以用指针代替字符串来比较。通常，Python 程序使用到的名称会被自动驻
   留，且用于保存模块、类或实例属性的字典的键也已驻留。

   驻留字符串不是永久存在的，对 "intern()" 返回值的引用必须保留下来，
   才能发挥驻留字符串的优势。

sys.is_finalizing()

   如果 Python 解释器 *正在关闭* 则返回 "True"，否则返回 "False"。

   在 3.5 版本加入.

sys.last_exc

   该变量并非总是会被定义；当有未处理的异常时它将被设为相应的异常实例
   并且解释器将打印异常消息和栈回溯。它的预期用途是允许交互用户导入调
   试器模块并进行事后调试而不必重新运行导致了错误的命令。 （典型用法是
   执行 "import pdb; pdb.pm()" 来进入事后调试器；请参阅 "pdb" 了解详情
   。）

   在 3.12 版本加入.

sys.last_type
sys.last_value
sys.last_traceback

   这三个变量已被弃用；请改用 "sys.last_exc"。 它们将保存
   "sys.last_exc" 的旧表示形式，如上面 "exc_info()" 所返回的。

sys.maxsize

   一个整数，表示 "Py_ssize_t" 类型的变量可以取到的最大值。在 32 位平
   台上通常为 "2**31 - 1"，在 64 位平台上通常为 "2**63 - 1"。

sys.maxunicode

   一个整数，表示最大的 Unicode 码点值，如 "1114111" （十六进制为
   "0x10FFFF" ）。

   在 3.3 版本发生变更: 在 **PEP 393** 之前，"sys.maxunicode" 曾是
   "0xFFFF" 或 "0x10FFFF"，具体取决于配置选项，该选项指定将 Unicode 字
   符存储为 UCS-2 还是 UCS-4。

sys.meta_path

   一个由 *元路径查找器* 对象组成的列表，将会调用这些对象的
   "find_spec()" 方法来确定其中的某个对象能否找到要导入的模块。 在默认
   情况下，它将存放实现了 Python 默认导入语法的条目。 调用
   "find_spec()" 方法至少需要附带待导入模块的绝对名称。 如果待导入模块
   包含在一个包中，则父包的 "__path__" 属性将作为第二个参数被传入。 此
   方法将返回一个 *模块规格说明*，或者如果找不到模块则返回 "None"。

   参见:

     "importlib.abc.MetaPathFinder"
        抽象基类，定义了 "meta_path" 内的查找器对象的接口。

     "importlib.machinery.ModuleSpec"
        "find_spec()" 返回的实例所对应的具体类。

   在 3.4 版本发生变更: *模块规格说明* 是在 Python 3.4 中根据 **PEP
   451** 引入的。

   在 3.12 版本发生变更: 移除了当 "meta_path" 条目没有 "find_spec()"
   方法时查找 "find_module()" 方法的回调。

sys.modules

   这是一个字典，它将模块名称映射到已经被加载的模块。 这可以被操纵来强
   制重新加载模块和其他技巧。然而，替换这个字典不一定会像预期的那样工
   作，从字典中删除重要的项目可能会导致 Python 出错。 如果你想对这个全
   局字典进行迭代，一定要使用 "sys.modules.copy()" 或
   "tuple(sys.modules)" 来避免异常，因为它的大小在迭代过程中可能会因为
   其他线程中的代码或活动的副作用而改变。

sys.orig_argv

   传给 Python 可执行文件的原始命令行参数列表。

   "sys.orig_argv" 中的元素是传给 Python 解释器的参数，而 "sys.argv"
   中的元素则是传给用户程序的参数。 解释器本身所使用的参数将出现在
   "sys.orig_argv" 中而不会出现在 "sys.argv" 中。

   在 3.10 版本加入.

sys.path

   一个由字符串组成的列表，用于指定模块的搜索路径。初始化自环境变量
   "PYTHONPATH"，再加上一条与安装有关的默认路径。

   在默认情况下，如在程序启动时被初始化的时候，会有潜在的不安全路径被
   添加到 "sys.path" 的开头 (在作为的 "PYTHONPATH" 结果被插入的条目 *
   之前* 位置):

   * "python -m module" 命令行：添加当前工作目录。

   * "python script.py" 命令行：添加脚本的目录。 如果是一个符号链接，
     则会解析符号链接。

   * "python -c code" 和 "python" (REPL) 命令行：添加一个空字符串，这
     表示当前工作目录。

   如果不想添加这个具有潜在不安全性的路径，请使用 "-P" 命令行选项或
   "PYTHONSAFEPATH" 环境变量。

   程序可以出于自己的目的随意修改此列表。 应当只将字符串添加到
   "sys.path" 中；所有其他数据类型都将在导入期间被忽略。

   参见:

     * "site" 模块，该模块描述了如何使用 .pth 文件来扩展 "sys.path"。

sys.path_hooks

   一个由可调用对象组成的列表，这些对象接受一个路径作为参数，并尝试为
   该路径创建一个 *查找器*。如果成功创建查找器，则可调用对象将返回它，
   否则将引发 "ImportError" 异常。

   本特性最早在 **PEP 302** 中被提及。

sys.path_importer_cache

   一个字典，作为 *查找器* 对象的缓存。key 是传入 "sys.path_hooks" 的
   路径，value 是相应已找到的查找器。如果路径是有效的文件系统路径，但
   在 "sys.path_hooks" 中未找到查找器，则存入 "None"。

   本特性最早在 **PEP 302** 中被提及。

sys.platform

   本字符串是一个平台标识符，举例而言，该标识符可用于将特定平台的组件
   追加到 "sys.path" 中。

   对于 Unix 系统（除 Linux 和 AIX 外），该字符串是 *Python 构建时的*
   "uname -s" 返回的小写操作系统名称，并附加了 "uname -r" 返回的系统版
   本的第一部分，如 "'sunos5'" 或 "'freebsd8'"。除非需要检测特定版本的
   系统，否则建议使用以下习惯用法:

      if sys.platform.startswith('freebsd'):
          # FreeBSD-specific code here...
      elif sys.platform.startswith('linux'):
          # Linux-specific code here...
      elif sys.platform.startswith('aix'):
          # AIX-specific code here...

   对于其他系统，值是：

   +------------------+-----------------------------+
   | 系统             | "平台" 值                   |
   |==================|=============================|
   | AIX              | "'aix'"                     |
   +------------------+-----------------------------+
   | Emscripten       | "'emscripten'"              |
   +------------------+-----------------------------+
   | Linux            | "'linux'"                   |
   +------------------+-----------------------------+
   | WASI             | "'wasi'"                    |
   +------------------+-----------------------------+
   | Windows          | "'win32'"                   |
   +------------------+-----------------------------+
   | Windows/Cygwin   | "'cygwin'"                  |
   +------------------+-----------------------------+
   | macOS            | "'darwin'"                  |
   +------------------+-----------------------------+

   在 3.3 版本发生变更: 在 Linux 上，"sys.platform" 将不再包含主要版本
   号。 它将总是 "'linux'"，而不是 "'linux2'" 或 "'linux3'"。 由于较旧
   的 Python 版本会包括版本号，因此推荐总是使用上述的 "startswith" 惯
   例写法。

   在 3.8 版本发生变更: 在 AIX 上，"sys.platform" 将不再包含主要版本号
   。 它将总是 "'aix'"，而不是 "'aix5'" 或 "'aix7'"。 由于较旧的
   Python 版本会包括版本号，因此推荐总是使用上述的 "startswith" 惯例写
   法。

   参见:

     "os.name" 具有更粗的粒度。 "os.uname()" 将给出依赖于具体系统的版
     本信息。

     "platform" 模块对系统的标识有更详细的检查。

sys.platlibdir

   平台专用库目录。用于构建标准库的路径和已安装扩展模块的路径。

   在大多数平台上，它等同于 ""lib"" 。在 Fedora 和 SuSE 上，它等同于给
   出了以下 "sys.path" 路径的 64 位平台上的 ""lib64"" （其中 "X.Y" 是
   Python 的 "major.minor" 版本）。

   * "/usr/lib64/pythonX.Y/"：标准库（如 "os" 模块的 "os.py" ）

   * "/usr/lib64/pythonX.Y/lib-dynload/"：标准库的 C 扩展模块（如
     "errno" 模块，确切的文件名取决于平台）

   * "/usr/lib/pythonX.Y/site-packages/" (请使用 "lib", 而非
     "sys.platlibdir"): 第三方模块

   * "/usr/lib64/pythonX.Y/site-packages/": 第三方包的 C 扩展模块

   在 3.9 版本加入.

sys.prefix

   一个指定用于安装与平台无关的 Python 文件的站点专属目录前缀的字符串
   ；在 Unix 上，默认为 "/usr/local"。 这可以在构建时通过将 "--prefix"
   参数传入 **configure** 脚本来设置。 请参阅 安装路径 了解衍生的路径
   。

   备注:

     如果在一个 虚拟环境 中，那么该值将在 "site.py" 中被修改，指向虚拟
     环境。Python 安装位置仍然可以用 "base_prefix" 来获取。

sys.ps1
sys.ps2

   字符串，指定解释器的首要和次要提示符。仅当解释器处于交互模式时，它
   们才有定义。这种情况下，它们的初值为 "'>>> '" 和 "'... '"。如果赋给
   其中某个变量的是非字符串对象，则每次解释器准备读取新的交互式命令时
   ，都会重新运行该对象的 "str()"，这可以用来实现动态的提示符。

sys.setdlopenflags(n)

   设置解释器在调用 "dlopen()" 时使用的旗标，例如当解释器加载扩展模块
   的时候。 首先，如果以 "sys.setdlopenflags(0)" 的形式调用的话这将在
   导入模块时启用符号的惰性求值。 要在扩展模块之间共享符号，请以
   "sys.setdlopenflags(os.RTLD_GLOBAL)" 的形式调用。 旗标志值的符号名
   称可以在 "os" 模块中找到 ("RTLD_*xxx*" 常量，例如 "os.RTLD_LAZY")。

   可用性: Unix。

sys.set_int_max_str_digits(maxdigits)

   设置解释器所使用的 整数字符串转换长度限制。 另请参阅
   "get_int_max_str_digits()"。

   在 3.11 版本加入.

sys.setprofile(profilefunc)

   设置系统的性能分析函数，该函数使得在 Py​​thon 中能够实现一个 Python
   源代码性能分析器。关于 Python Profiler 的更多信息请参阅 Python 性能
   分析器 章节。性能分析函数的调用方式类似于系统的跟踪函数（参阅
   "settrace()" ），但它是通过不同的事件调用的，例如，不是每执行一行代
   码就调用它一次（仅在调用某函数和从某函数返回时才会调用性能分析函数
   ，但即使某函数发生异常也会算作返回事件）。该函数是特定于单个线程的
   ，但是性能分析器无法得知线程之间的上下文切换，因此在存在多个线程的
   情况下使用它是没有意义的。另外，因为它的返回值不会被用到，所以可以
   简单地返回 "None"。性能分析函数中的错误将导致其自身被解除设置。

   备注:

     "setprofile()" 使用与 "settrace()" 相同的跟踪机制。 要在跟踪函数
     内部使用 "setprofile()" 来跟踪调用（例如在调试器断点内），请参阅
     "call_tracing()"。

   性能分析函数应接收三个参数：*frame*、*event* 和 *arg*。*frame* 是当
   前的堆栈帧。*event* 是一个字符串："'call'"、"'return'"、"'c_call'"
   、"'c_return'" 或 "'c_exception'"。*arg* 取决于事件类型。

   这些事件具有以下含义：

   "'call'"
      表示调用了某个函数（或进入了其他的代码块）。性能分析函数将被调用
      ，*arg* 为 "None"。

   "'return'"
      表示某个函数（或别的代码块）即将返回。性能分析函数将被调用，
      *arg* 是即将返回的值，如果此次返回事件是由于抛出异常，*arg* 为
      "None"。

   "'c_call'"
      表示即将调用某个 C 函数。它可能是扩展函数或是内建函数。*arg* 是
      C 函数对象。

   "'c_return'"
      表示返回了某个 C 函数。*arg* 是 C 函数对象。

   "'c_exception'"
      表示某个 C 函数抛出了异常。*arg* 是 C 函数对象。

   引发一个 审计事件 "sys.setprofile"，不附带任何参数。

sys.setrecursionlimit(limit)

   将 Python 解释器堆栈的最大深度设置为 *limit*。此限制可防止无限递归
   导致的 C 堆栈溢出和 Python 崩溃。

   不同平台所允许的最高限值不同。当用户有需要深度递归的程序且平台支持
   更高的限值，可能就需要调高限值。进行该操作需要谨慎，因为过高的限值
   可能会导致崩溃。

   如果新的限值低于当前的递归深度，将抛出 "RecursionError" 异常。

   在 3.5.1 版本发生变更: 如果新的限值低于当前的递归深度，现在将抛出
   "RecursionError" 异常。

sys.setswitchinterval(interval)

   设置解释器的线程切换间隔时间（单位为秒）。该浮点数决定了“时间片”的
   理想持续时间，时间片将分配给同时运行的 Python 线程。请注意，实际值
   可能更高，尤其是使用了运行时间长的内部函数或方法时。同时，在时间间
   隔末尾调度哪个线程是操作系统的决定。解释器没有自己的调度程序。

   在 3.2 版本加入.

sys.settrace(tracefunc)

   设置系统的跟踪函数，使得用户在 Python 中就可以实现 Python 源代码调
   试器。该函数是特定于单个线程的，所以要让调试器支持多线程，必须为正
   在调试的每个线程都用 "settrace()" 注册一个跟踪函数，或使用
   "threading.settrace()"。

   跟踪函数应接收三个参数：*frame*、*event* 和 *arg*。*frame* 是当前的
   堆栈帧。*event* 是一个字符串："'call'"、"'line'"、"'return'"、
   "'exception'" 或 "'opcode'"。*arg* 取决于事件类型。

   每次进入 trace 函数的新的局部作用范围，都会调用 trace 函数（
   *event* 会被设置为 "'call'" ），它应该返回一个引用，指向即将用在新
   作用范围上的局部跟踪函数；如果不需要跟踪当前的作用范围，则返回
   "None"。

   本地跟踪函数应返回对自身的引用，或对另一个函数的引用然后将其用作本
   作用域的局部跟踪函数。

   如果跟踪函数出错，则该跟踪函数将被取消设置，类似于调用
   "settrace(None)"。

   备注:

     在调用跟踪函数（例如由 "settrace()" 设置的函数）时将禁用跟踪。 有
     关递归跟踪请参阅 "call_tracing()"。

   这些事件具有以下含义：

   "'call'"
      表示调用了某个函数（或进入了其他的代码块）。全局跟踪函数将被调用
      ，*arg* 为 "None"。返回值将指定局部跟踪函数。

   "'line'"
      解释器即将执行一个新的代码行或重新执行一个循环的条件。 局部跟踪
      函数将被调用；*arg* 为 "None"；其返回值将指定新的局部跟踪函数。
      请参阅 "Objects/lnotab_notes.txt" 查看有关其工作原理的详细说明。
      可以通过在某个 帧 上把 "f_trace_lines" 设为 "False" 来禁用相应帧
      的每行触发事件。

   "'return'"
      表示某个函数（或别的代码块）即将返回。局部跟踪函数将被调用，
      *arg* 是即将返回的值，如果此次返回事件是由于抛出异常，*arg* 为
      "None"。跟踪函数的返回值将被忽略。

   "'exception'"
      表示发生了某个异常。局部跟踪函数将被调用，*arg* 是一个
      "(exception, value, traceback)" 元组，返回值将指定新的局部跟踪函
      数。

   "'opcode'"
      解释器即将执行一个新的操作码（请参阅 "dis" 了解有关操作码的详情
      ）。 局部跟踪函数将被调用；*arg* 为 "None"；共返回值将指定新的局
      部跟踪函数。 在默认情况下不会发出每个操作码触发事件：必须通过在
      某个 帧 上把 "f_trace_opcodes" 设为 "True" 来显式地发出请求。

   注意，由于异常是在链式调用中传播的，所以每一级都会产生一个
   "'exception'" 事件。

   更细微的用法是，可以显式地通过赋值 "frame.f_trace = tracefunc" 来设
   置跟踪函数，而不是用现有跟踪函数的返回值去间接设置它。当前帧上的跟
   踪函数必须激活，而 "settrace()" 还没有做这件事。注意，为了使上述设
   置起效，必须使用 "settrace()" 来安装全局跟踪函数才能启用运行时跟踪
   机制，但是它不必与上述是同一个跟踪函数（它可以是一个开销很低的跟踪
   函数，只返回 "None"，即在各个帧上立即将其自身禁用）。

   关于代码对象和帧对象的更多信息请参考 标准类型层级结构。

   引发一个 审计事件 "sys.settrace"，不附带任何参数。

   **CPython 实现细节：** "settrace()" 函数仅用于实现调试器，性能分析
   器，打包工具等。它的行为是实现平台的一部分，而不是语言定义的一部分
   ，因此并非在所有 Python 实现中都可用。

   在 3.7 版本发生变更: 添加了 "'opcode'" 事件类型；为帧添加了
   "f_trace_lines" 和 "f_trace_opcodes" 属性

   在 3.12 版本发生变更: "'opcode'" 事件仅当至少有一个帧的
   "f_trace_opcodes" 在调用 "settrace()" 之前被设为 "True" 时被发出。
   此行为将在 3.13 中被改回与之前的版本保持一致。

sys.set_asyncgen_hooks([firstiter] [, finalizer])

   接受两个可选的关键字参数，要求它们是可调用对象，且接受一个 *异步生
   成器迭代器* 作为参数。*firstiter* 对象将在异步生成器第一次迭代时调
   用。*finalizer* 将在异步生成器即将被销毁时调用。

   引发一个 审计事件 "sys.set_asyncgen_hooks_firstiter"，不附带任何参
   数。

   引发一个 审计事件 "sys.set_asyncgen_hooks_finalizer"，不附带任何参
   数。

   之所以会引发两个审计事件，是因为底层的 API 由两个调用组成，每个调用
   都须要引发自己的事件。

   在 3.6 版本加入: 更多详情请参阅 **PEP 525**，*finalizer* 方法的参考
   示例可参阅 Lib/asyncio/base_events.py 中
   "asyncio.Loop.shutdown_asyncgens" 的实现。

   备注:

     本函数已添加至暂定软件包（详情请参阅 **PEP 411** ）。

sys.set_coroutine_origin_tracking_depth(depth)

   用于启用或禁用协程溯源。启用后，协程对象上的 "cr_origin" 属性将包含
   一个元组，它由多个（文件名 filename，行号 line number，函数名
   function name）元组组成，整个元组描述出了协程对象创建过程的回溯，元
   组首端是最近一次的调用。禁用后，"cr_origin" 将为 None。

   要启用，请向 *depth* 传递一个大于零的值，它指定了有多少帧将被捕获信
   息。要禁用，请将 *depth* 置为零。

   该设置是特定于单个线程的。

   在 3.7 版本加入.

   备注:

     本函数已添加至暂定软件包（详情请参阅 **PEP 411** ）。仅将其用于调
     试目的。

sys.activate_stack_trampoline(backend, /)

   激活栈性能分析器 trampoline *backend*。 唯一受支持的后端是 ""perf""
   。

   可用性: Linux。

   在 3.12 版本加入.

   参见:

     * Python 对 Linux perf 性能分析器的支持

     * https://perf.wiki.kernel.org

sys.deactivate_stack_trampoline()

   取消激活当前的栈性能分析器 trampoline 后端。

   如果没有激活的栈性能分析器，此函数将没有任何效果。

   可用性: Linux。

   在 3.12 版本加入.

sys.is_stack_trampoline_active()

   如果激活了栈性能分析器 trampoline 则返回 "True"。

   可用性: Linux。

   在 3.12 版本加入.

sys._enablelegacywindowsfsencoding()

   将 *filesystem encoding and error handler* 分别修改为 'mbcs' 和
   'replace'，以便与 3.6 之前版本的 Python 保持一致。

   这等同于在启动 Python 前先定义好 "PYTHONLEGACYWINDOWSFSENCODING" 环
   境变量。

   另请参阅 "sys.getfilesystemencoding()" 和
   "sys.getfilesystemencodeerrors()"。

   可用性: Windows。

   在 3.6 版本加入: 更多详情请参阅 **PEP 529**。

sys.stdin
sys.stdout
sys.stderr

   解释器用于标准输入、标准输出和标准错误的 *文件对象*：

   * "stdin" 用于所有交互式输入（包括对 "input()" 的调用）；

   * "stdout" 用于 "print()" 和 *expression* 语句的输出，以及用于
     "input()" 的提示符；

   * 解释器自身的提示符和它的错误消息都发往 "stderr"。

   这些流都是常规 *文本文件*，与 "open()" 函数返回的对象一致。它们的参
   数选择如下：

   * 编码格式和错误处理句柄是由 "PyConfig.stdio_encoding" 和
     "PyConfig.stdio_errors" 来初始化的。

     在 Windows 上，控制台设备使用 UTF-8。 非字符设备如磁盘文件和管道
     使用系统语言区域编码格式（例如 ANSI 代码页）。 非控制台字符设备如
     NUL（例如当 "isatty()" 返回 "True" 时）会在启动时分别让 stdin 和
     stdout/stderr 使用控制台输入和输出代码页。 如果进程初始化时没有被
     附加到控制台则会使用默认的系统 *locale encoding*。

     要重写控制台的特殊行为，可以在启动 Python 前设置
     PYTHONLEGACYWINDOWSSTDIO 环境变量。此时，控制台代码页将用于其他字
     符设备。

     在所有平台上，都可以通过在 Python 启动前设置 "PYTHONIOENCODING"
     环境变量来重写字符编码，或通过新的 "-X" "utf8" 命令行选项和
     "PYTHONUTF8" 环境变量来设置。但是，对 Windows 控制台来说，上述方
     法仅在设置了 "PYTHONLEGACYWINDOWSSTDIO" 后才起效。

   * 交互模式下，"stdout" 流是行缓冲的。其他情况下，它像常规文本文件一
     样是块缓冲的。两种情况下的 "stderr" 流都是行缓冲的。要使得两个流
     都变成无缓冲，可以传入 "-u" 命令行选项或设置 "PYTHONUNBUFFERED"
     环境变量。

   在 3.9 版本发生变更: 非交互模式下，"stderr" 现在是行缓冲的，而不是
   全缓冲的。

   备注:

     要从标准流写入或读取二进制数据，请使用底层二进制 "buffer" 对象。
     例如，要将字节写入 "stdout"，请使用
     "sys.stdout.buffer.write(b'abc')"。但是，如果你正在编写一个库（并
     且不能控制其代码执行所在的上下文），请注意标准流可能会被不支持
     "buffer" 属性的文件型对象如 "io.StringIO" 所取代。

sys.__stdin__
sys.__stdout__
sys.__stderr__

   程序开始时，这些对象存有 "stdin"、"stderr" 和 "stdout" 的初始值。它
   们在程序结束前都可以使用，且在需要向实际的标准流打印内容时很有用，
   无论 "sys.std*" 对象是否已重定向。

   如果实际文件已经被覆盖成一个损坏的对象了，那它也可用于将实际文件还
   原成能正常工作的文件对象。但是，本过程的最佳方法应该是，在原来的流
   被替换之前就显式地保存它，并使用这一保存的对象来还原。

   备注:

     某些情况下的 "stdin"、"stdout" 和 "stderr" 以及初始值 "__stdin__"
     、"__stdout__" 和 "__stderr__" 可以是 "None"。通常发生在未连接到
     控制台的 Windows GUI app 中，以及在用 **pythonw** 启动的 Python
     app 中。

sys.stdlib_module_names

   一个包含标准库模组名称字符串的冻结集合。

   它在所有平台上都保持一致。 在某些平台上不可用的模块和在 Python 编译
   时被禁用的模块也会被列出。 所有种类的模块都会被列出：纯 Python 模块
   、内置模块、冻结模块和扩展模块等。  测试模块则会被排除掉。

   对于包来说，仅会列出主包：子包和子模块不会被列出。 例如，"email" 包
   会被列出，但 "email.mime" 子包和 "email.message" 子模块不会被列出。

   另请参阅 "sys.builtin_module_names" 列表。

   在 3.10 版本加入.

sys.thread_info

   一个 *具名元组*，包含线程实现的信息。

   thread_info.name

      线程实现的名称：

      * ""nt"": Windows 线程

      * ""pthread"": POSIX 线程

      * ""pthread-stubs"": 转存 POSIX 线程（在不支持线程的 WebAssembly
        平台上）

      * ""solaris"": Solaris 线程

   thread_info.lock

      锁实现的名称：

      * ""semaphore"": 锁使用一个寄存器

      * ""mutex+cond"": 锁使用互斥和条件变量

      * "None" 如果此信息未知

   thread_info.version

      线程库的名称和版本。 它是一个字符串，如果此信息未知则为 "None"。

   在 3.3 版本加入.

sys.tracebacklimit

   当该变量值设置为整数，在发生未处理的异常时，它将决定打印的回溯信息
   的最大层级数。默认为 "1000"。当将其设置为 "0" 或小于 0，将关闭所有
   回溯信息，并且只打印异常类型和异常值。

sys.unraisablehook(unraisable, /)

   处理一个无法抛出的异常。

   它会在发生了一个异常但 Python 没有办法处理时被调用。例如，当一个析
   构器引发了异常，或在垃圾回收 ("gc.collect()") 期间引发了异常。

   *unraisable* 参数具有以下属性:

   * "exc_type": 异常类型。

   * "exc_value": 异常值，可以为 "None"。

   * "exc_traceback": 异常回溯，可以为 "None"。

   * "err_msg": 错误消息，可以为 "None"。

   * "object": 导致异常的对象，可以为 "None"。

   默认的钩子会将 "err_msg" 和 "object" 格式化为: "f'{err_msg}:
   {object!r}'"；如果 "err_msg" 为 "None" 则会使用 "Exception ignored
   in" 错误消息。

   要改变无法抛出的异常的处理过程，可以重写 "sys.unraisablehook()"。

   参见: "excepthook()" 处理未捕获的异常。

   警告:

     使用自定义钩子存储 "exc_value" 可能会创建引用循环。 当该异常不再
     需要时应当显式地清空以打破引用循环。使用自定义钩子存储 "object"
     可能会在它被设为正在终结的对象时将其复活。 为避免对象复活应当避免
     在自定义钩子完成后存储 "object"。

   引发一个审计事件 "sys.unraisablehook" 并附带参数 "hook",
   "unraisable"。

   在 3.8 版本加入.

sys.version

   一个包含 Python 解释器版本号加编译版本号以及所用编译器等额外信息的
   字符串。 此字符串会在交互式解释器启动时显示。 请不要从中提取版本信
   息，而应当使用 "version_info" 以及 "platform" 模块所提供的函数。

sys.api_version

   这个解释器的 C API 版本。当你在调试 Python及期扩展模板的版本冲突这
   个功能非常有用。

sys.version_info

   一个包含版本号五部分的元组: *major*, *minor*, *micro*,
   *releaselevel* 和 *serial*。 除 *releaselevel* 外的所有值均为整数；
   发布级别值则为 "'alpha'", "'beta'", "'candidate'" 或 "'final'"。 对
   应于 Python 版本 2.0 的 "version_info" 值为 "(2, 0, 0, 'final', 0)"
   。 这些部分也可按名称访问，因此 "sys.version_info[0]" 就等价于
   "sys.version_info.major"，依此类推。

   在 3.1 版本发生变更: 增加了以名称表示的各部分属性。

sys.warnoptions

   这是警告框架的一个实现细节；请不要修改此值。 有关警告框架的更多信息
   请参阅 "warnings" 模块。

sys.winver

   用于在 Windows 平台上作为注册表键的版本号。这在 Python DLL 中被存储
   为 1000 号字符串资源。 其值通常是正在运行的 Python 解释器的主要和次
   要版本号。 它在 "sys" 模块中提供是为了信息展示目的；修改此值不会影
   响 Python 所使用的注册表键。

   可用性: Windows。

sys.monitoring

   包含用于注册回调和控制监控事件的函数和常量的命名空间。 详情参见
   "sys.monitoring"。

sys._xoptions

   一个字典，包含通过 "-X" 命令行选项传递的旗标，这些旗标专属于各种具
   体实现。选项名称将会映射到对应的值（如果显式指定）或者 "True"。例如
   :

      $ ./python -Xa=b -Xc
      Python 3.2a3+ (py3k, Oct 16 2010, 20:14:50)
      [GCC 4.4.3] on linux2
      Type "help", "copyright", "credits" or "license" for more information.
      >>> import sys
      >>> sys._xoptions
      {'a': 'b', 'c': True}

   **CPython 实现细节：** 这是 CPython 专属的访问通过 "-X" 传递的选项
   的方式。 其他实现可能会通过其他方式导出它们，或者完全不导出。

   在 3.2 版本加入.

-[ 引用 ]-

[C99] ISO/IEC 9899:1999.  "Programming languages -- C."  该标准的公开
      草案可从 https://www.open-
      std.org/jtc1/sc22/wg14/www/docs/n1256.pdf 获得。
