O que há de novo no Python 3.14¶
- Editor:
Hugo van Kemenade
Esse artigo explica os novos recursos no Python 3.14. comparado ao 3.13.
Para detalhes completos, veja o changelog.
Ver também
PEP 745 – Cronograma de lançamento do Python 3.14
Nota
Os usuários de pré-lançamento devem estar cientes de que este documento está atualmente em forma de rascunho. Ele será atualizado substancialmente à medida que o Python 3.14 caminha para seu lançamento estável, portanto vale a pena conferir mesmo depois de ler as versões anteriores.
Resumo – destaques da versão¶
O Python 3.14 vai ser o lançamento estável mais recente da linguagem de programação Python, com uma mistura de alterações na linguagem, na implementação e na biblioteca padrão.
As maiores mudanças no implementação incluem as strings template (PEP 750), a avaliação adiada de anotações (PEP 649) e um novo tipo de interpretador que usa a chamada de cauda.
As alterações na biblioteca incluem o acréscimo de um novo módulo, annotationlib
(PEP 749), para introspecção e empacotamento de anotações (PEP 649), um novo módulo, compression.zstd
, para suporte ao Zstandard (PEP 784), além de destaque de sintaxe no REPL, bem como descontinuações e remoções habituais e melhorias na facilidade de uso e correções.
Alterações incompatíveis¶
Em plataformas diferentes de macOS e Windows, o método de início padrão para multiprocessing
e ProcessPoolExecutor
muda de fork para forkserver.
Consulte (1) e (2) para detalhes.
Se você encontrar NameError
s ou erros de serialização com pickle vindos de multiprocessing
ou concurrent.futures
, consulte as restrições do forkserver.
O interpretador evita algumas modificações na contagem de referências internamente quando é seguro fazê-lo. Isso pode levar a valores diferentes retornados de sys.getrefcount()
e Py_REFCNT()
em comparação com versões anteriores do Python. Consulte abaixo para obter detalhes.
Novas funcionalidades¶
PEP 779: Python com threads livres é oficialmente suportado¶
A construção do Python com threads livres agora é suportada e não mais experimental. Este é o início da fase II, na qual o Python com threads livres é oficialmente suportado, mas ainda é opcional.
Estamos confiantes de que o projeto está no caminho certo e agradecemos a dedicação contínua de todos que trabalham para deixar o modo threads livres pronto para uma adoção mais ampla na comunidade Python.
Com essas recomendações e a aceitação desta PEP, nós, como comunidade de desenvolvedores Python, devemos anunciar amplamente que threads livres é uma opção de construção do Python suportada agora e no futuro, e que ela não será removida sem um cronograma de descontinuação adequado.
Qualquer decisão de transição para a fase III, com o uso de threads livres como versão padrão ou única do Python, ainda está indefinida e depende de muitos fatores, tanto dentro do próprio CPython quanto da comunidade. Esta decisão é para o futuro.
PEP 734: múltiplos interpretadores na biblioteca padrão¶
O ambiente de execução do CPython permite a execução simultânea de várias cópias do Python no mesmo processo há mais de 20 anos. Cada uma dessas cópias separadas é chamada de “interpretador”. No entanto, o recurso estava disponível apenas por meio da API C.
Essa limitação foi removida na versão 3.14, com o novo módulo concurrent.interpreters
.
Há pelo menos dois motivos importantes pelos quais vale a pena considerar o uso de múltiplos interpretadores:
eles oferecem suporte a um novo modelo (para Python) de simultaneidade, amigável ao ser humano
verdadeiro paralelismo multi-core
Para alguns casos de uso, a simultaneidade em software permite eficiência e pode simplificar o software em alto nível. Ao mesmo tempo, implementar e manter todos os tipos de simultaneidade, exceto as mais simples, costuma ser uma luta para o cérebro humano. Isso se aplica especialmente a threads simples (por exemplo, threading
), onde toda a memória é compartilhada entre todas as threads.
Com múltiplos interpretadores isolados, você pode aproveitar uma classe de modelos de simultaneidade, como CSP ou o modelo de ator, que obtiveram sucesso em outras linguagens de programação, como Smalltalk, Erlang, Haskell e Go. Pense em múltiplos interpretadores como threads, mas com compartilhamento opt-in.
Sobre o paralelismo multinúcleo: a partir da versão 3.12, os interpretadores agora estão suficientemente isolados uns dos outros para serem usados em paralelo. (Veja PEP 684.) Isso destrava uma variedade de casos de uso intensivos de CPU para Python que eram limitados pela GIL.
O uso de múltiplos interpretadores é semelhante em muitos aspectos ao multiprocessing
, pois ambos fornecem “processos” lógicos isolados que podem ser executados em paralelo, sem compartilhamento por padrão. No entanto, ao usar múltiplos interpretadores, uma aplicação usará menos recursos do sistema e operará com mais eficiência (já que permanece dentro do mesmo processo). Pense em múltiplos interpretadores como se tivessem o isolamento de processos com a eficiência de threads.
Embora o recurso já exista há décadas, múltiplos interpretadores não têm sido amplamente utilizados devido à baixa conscientização e à ausência de um módulo da biblioteca padrão. Consequentemente, eles atualmente apresentam diversas limitações notáveis, que melhorarão significativamente agora que o recurso finalmente está se tornando popular.
Limitações atuais:
iniciar cada interpretador ainda não foi otimizado
cada interpretador usa mais memória do que o necessário (trabalharemos em seguida no compartilhamento interno extensivo entre interpretadores)
não há muitas opções ainda para realmente compartilhar objetos ou outros dados entre interpretadores (além de
memoryview
)muitos módulos de extensão no PyPI ainda não são compatíveis com múltiplos interpretadores (os módulos de extensão stdlib são compatíveis)
a abordagem para escrever aplicações que usam vários interpretadores isolados é, em grande parte, desconhecida para usuários do Python, por enquanto
O impacto dessas limitações dependerá de futuras melhorias no CPython, do uso dos interpretadores e do que a comunidade resolver por meio dos pacotes PyPI. Dependendo do caso de uso, as limitações podem não ter muito impacto, então experimente!
Além disso, versões futuras do CPython reduzirão ou eliminarão a sobrecarga e fornecerão utilitários menos apropriados no PyPI. Enquanto isso, a maioria das limitações também pode ser solucionada por meio de módulos de extensão, o que significa que os pacotes do PyPI podem preencher qualquer lacuna da versão 3.14 e até mesmo da versão 3.12, onde os interpretadores foram finalmente isolados adequadamente e pararam de compartilhar a GIL. Da mesma forma, esperamos ver gradualmente bibliotecas no PyPI para abstrações de alto nível sobre os interpretadores.
Em relação aos módulos de extensão, estamos trabalhando para atualizar alguns projetos PyPI, bem como ferramentas como Cython, pybind11, nanobind e PyO3. As etapas para isolar um módulo de extensão podem ser encontradas em Isolando módulos de extensão. O isolamento de um módulo tem muitas sobreposições com o que é necessário para oferecer suporte a threads livres, portanto, o trabalho contínuo da comunidade nessa área ajudará a acelerar o suporte a múltiplos interpretadores.
Também adicionado no 3.14: concurrent.futures.InterpreterPoolExecutor.
Ver também
PEP 750: strings template¶
Literais de string template (t-strings) são uma generalização de f-strings, usando um t
no lugar do prefixo f
. Em vez de serem avaliadas como str
, as t-strings são avaliadas como um novo tipo string.templatelib.Template
:
from string.templatelib import Template
name = "Mundo"
template: Template = t"Olá {name}"
O modelo pode então ser combinado com funções que operam na estrutura do template para produzir um str
ou um resultado semelhante a uma string. Por exemplo, sanitizando a entrada:
evil = "<script>alert('evil')</script>"
template = t"<p>{evil}</p>"
assert html(template) == "<p><script>alert('evil')</script></p>"
Como outro exemplo, gerando atributos HTML a partir de dados:
attributes = {"src": "shrubbery.jpg", "alt": "looks nice"}
template = t"<img {attributes}>"
assert html(template) == '<img src="shrubbery.jpg" alt="looks nice" />'
Em comparação com o uso de uma f-string, a função html
tem acesso a atributos de modelo que contêm as informações originais: strings estáticas, interpolações e valores do escopo original. Ao contrário das abordagens de modelo existentes, as t-strings são construídas a partir da sintaxe e das regras conhecidas das f-strings. Os sistemas de template, portanto, se beneficiam das ferramentas Python, pois estão muito mais próximos da linguagem Python, da sintaxe, do escopo e de outros aspectos.
Escrever manipuladores de template é simples:
from string.templatelib import Template, Interpolation
def lower_upper(template: Template) -> str:
"""Renderiza as partes estáticas em minúsculas e as interpolações em maiúsculas."""
parts: list[str] = []
for item in template:
if isinstance(item, Interpolation):
parts.append(str(item.value).upper())
else:
parts.append(item.lower())
return "".join(parts)
name = "mundo"
assert lower_upper(t"OLÁ {name}") == "olá MUNDO"
Com isso, os desenvolvedores podem escrever sistemas de modelo para higienizar SQL, fazer operações de shell seguras, melhorar o registro, abordar ideias modernas em desenvolvimento web (HTML, CSS e assim por diante) e implementar DSLs comerciais leves e personalizadas.
(Contribuição de Jim Baker, Guido van Rossum, Paul Everitt, Koudai Aono, Lysandros Nikolaou, Dave Peck, Adam Turner, Jelle Zijlstra, Bénédikt Tran e Pablo Galindo Salgado em gh-132661.)
Ver também
PEP 768: interface segura para depurador externo para o CPython¶
PEP 768 introduz uma interface de depuração sem sobrecarga que permite que depuradores e perfiladores se conectem com segurança a processos Python em execução. Esta é uma melhoria significativa nos recursos de depuração do Python, permitindo que depuradores renunciem a alternativas inseguras. Veja abaixo para saber como este recurso é utilizado para implementar os recursos de conexão remota do novo módulo pdb
.
A nova interface fornece pontos de execução seguros para anexar código do depurador sem modificar o caminho de execução normal do interpretador ou adicionar sobrecarga de tempo de execução. Isso permite que as ferramentas inspecionem e interajam com aplicações Python em tempo real sem interrompê-las ou reiniciá-las — um recurso crucial para sistemas de alta disponibilidade e ambientes de produção.
Por conveniência, o CPython implementa essa interface por meio do módulo sys
com uma função sys.remote_exec()
:
sys.remote_exec(pid, script_path)
Esta função permite o envio de código Python para ser executado em um processo de destino no próximo ponto de execução seguro. No entanto, os autores da ferramenta também podem implementar o protocolo diretamente, conforme descrito na PEP, que detalha os mecanismos subjacentes usados para anexar com segurança a processos em execução.
Aqui está um exemplo simples que inspeciona tipos de objetos em um processo Python em execução:
import os import sys import tempfile # Cria um script temporário with tempfile.NamedTemporaryFile(mode='w', suffix='.py', delete=False) as f: script_path = f.name f.write(f"import my_debugger; my_debugger.connect({os.getpid()})") try: # Executa no processo com PID 1234 print("Vejam! Eis uma oferta!:") sys.remote_exec(1234, script_path) finally: os.unlink(script_path)
A interface de depuração foi cuidadosamente projetada com a segurança em mente e inclui vários mecanismos para controlar o acesso:
Uma variável de ambiente
PYTHON_DISABLE_REMOTE_DEBUG
.Uma opção de linha de comando
-X disable-remote-debug
.Um sinalizador de configuração
--without-remote-debug
para desabilitar completamente o recurso no momento da construção.
Um detalhe importante da implementação é que a interface se baseia no laço de avaliação existente do interpretador e nos pontos seguros, garantindo sobrecarga zero durante a execução normal e, ao mesmo tempo, fornecendo uma maneira confiável para processos externos coordenarem operações de depuração.
(Contribuição de Pablo Galindo Salgado, Matt Wozniski e Ivona Stojanovic em gh-131591.)
Ver também
PEP 784: adicionando Zstandard à biblioteca padrão¶
O novo pacote compression
contém os módulos compression.lzma
, compression.bz2
, compression.gzip
e compression.zlib
, que reexportam os módulos lzma
, bz2
, gzip
e zlib
, respectivamente. Os novos nomes de importação em compression
são os nomes canônicos para a importação desses módulos de compactação daqui para frente. No entanto, os nomes dos módulos existentes não foram descontinuados. Qualquer descontinuação ou remoção dos módulos de compressão existentes ocorrerá no mínimo cinco anos após o lançamento da versão 3.14.
O novo módulo compression.zstd
fornece APIs de compactação e descompactação para o formato Zstandard por meio de ligações à biblioteca zstd da Meta. O Zstandard é um formato de compactação amplamente adotado, altamente eficiente e rápido. Além das APIs introduzidas em compression.zstd
, o suporte para leitura e gravação de arquivos compactados do Zstandard foi adicionado aos módulos tarfile
, zipfile
e shutil
.
Aqui está um exemplo de uso do novo módulo para compactar alguns dados:
from compression import zstd
import math
data = str(math.pi).encode() * 20
compressed = zstd.compress(data)
ratio = len(compressed) / len(data)
print(f"Foi alcançada uma taxa de compactação de {ratio}")
Como pode ser visto, a API é semelhante às APIs dos módulos lzma
e bz2
.
(Contribuição de Emma Harper Smith, Adam Turner, Gregory P. Smith, Tomas Roun, Victor Stinner e Rogdham em gh-132983.)
Ver também
Anexação remota a um processo Python em execução com PDB¶
O módulo pdb
agora suporta anexação remota a um processo Python em execução usando uma nova opção de linha de comando -p PID
:
python -m pdb -p 1234
Isso se conectará ao processo Python com o PID fornecido e permitirá que você o depure interativamente. Observe que, devido ao funcionamento do interpretador Python, a conexão a um processo remoto bloqueado em uma chamada de sistema ou aguardando E/S só funcionará quando a próxima instrução de bytecode for executada ou quando o processo receber um sinal.
Este recurso usa PEP 768 e a função sys.remote_exec()
para anexar ao processo remoto e enviar os comandos PDB a ele.
(Contribuição de Matt Wozniski e Pablo Galindo em gh-131591.)
Ver também
PEP 758 – permite expressões except e except* sem parênteses¶
As expressões except
e except*
agora permitem a omissão de parênteses quando há vários tipos de exceção e a cláusula as
não é usada. Por exemplo, as seguintes expressões agora são válidas:
try:
connect_to_server()
except TimeoutError, ConnectionRefusedError:
print("Problema de rede encontrado.")
# O mesmo se aplica a except* (para grupos de exceções):
try:
connect_to_server()
except* TimeoutError, ConnectionRefusedError:
print("Problema de rede encontrado.")
Confira PEP 758 para mais detalhes.
(Contribuição de Pablo Galindo e Brett Cannon em gh-131831.)
Ver também
PEP 649 e 749: avaliação adiada de anotações¶
As anotações em funções, classes e módulos não são mais avaliados de forma ansiosa. Em vez disso, as anotações são armazenadas em uma função de anotação com propósito especial e avaliadas somente quando necessário (exceto se from __future__ import annotations
for usado). Isso está especificado nas PEP 649 e PEP 749.
Essa alteração foi projetada para tornar anotações em Python mais eficientes e mais utilizáveis na maioria das circunstâncias. O custo em tempo de execução para definir anotação é minimizado, mas continua sendo possível introspectar anotação em tempo de execução. Não é mais necessário incluir anotação em strings se eles contiverem referências futuras.
O novo módulo annotationlib
fornece ferramentas para inspecionar anotação adiada. A anotação pode ser avaliada nos formatos VALUE
(que avalia anotações para valores em tempo de execução, semelhante ao comportamento nas versões anteriores do Python), FORWARDREF
(que substitui nomes indefinidos por marcadores especiais) e STRING
(que retorna anotações como strings).
Este exemplo mostra como esses formatos se comportam:
>>> from annotationlib import get_annotations, Format
>>> def func(arg: Undefined):
... pass
>>> get_annotations(func, format=Format.VALUE)
Traceback (most recent call last):
...
NameError: name 'Undefined' is not defined
>>> get_annotations(func, format=Format.FORWARDREF)
{'arg': ForwardRef('Undefined', owner=<function func at 0x...>)}
>>> get_annotations(func, format=Format.STRING)
{'arg': 'Undefined'}
Implicações para o código anotado¶
Se você definir anotação em seu código (por exemplo, para uso com um verificador de tipo estático), essa alteração provavelmente não o afetará: você pode continuar escrevendo anotação da mesma forma que fazia com as versões anteriores de Python.
É provável que você consiga remover as strings entre aspas em anotações, que são frequentemente usadas para referência futura. Da mesma forma, se você usar from __future__ import annotations
para evitar ter que escrever strings em anotações, poderá remover essa importação se você for manter seu código apenas para Python 3.14 e mais recentes. No entanto, se você depende de bibliotecas de terceiros que leem anotações, essas bibliotecas podem precisar de alterações no suporte a anotações sem aspas para funcionarem como esperado.
Implicações para leitores de __annotations__
¶
Se o seu código lê o atributo __annotations__
dos objetos, talvez você queira fazer alterações para prover suporte a código que depende da avaliação adiada de anotações. Por exemplo, talvez você queira usar annotationlib.get_annotations()
com o formato FORWARDREF
, como o módulo dataclasses
faz agora.
O pacote externo typing_extensions fornece compatibilidade retroativa parcial de algumas das funcionalidades do módulo annotationlib
, como a enumeração Format
e a função get_annotations()
. Eles podem ser usados para escrever código com versão-cruzada que aproveite as vantagens do novo comportamento em Python 3.14.
from __future__ import annotations
¶
No Python 3.7, a PEP 563 introduziu a diretiva from __future__ import annotations
, que transforma todas as anotações em strings. Essa diretiva agora é considerada descontinuada e espera-se que seja removida em uma futura versão do Python. No entanto, essa remoção só ocorrerá depois que Python 3.13, a última versão sem avaliação adiada de anotação, chegar ao fim de sua vida útil em 2029. No Python 3.14, o comportamento do código que usa from __future__ import annotations
não foi alterado.
(Contribuição de Jelle Zijlstra em gh-119180, PEP 649 foi escrita por Larry Hastings.)
Mensagens de erro melhoradas¶
O interpretador agora fornece sugestões úteis ao detectar erros de digitação em palavras reservadas do Python. Ao encontrar uma palavra que se assemelha muito a uma palavra reservada do Python, o interpretador sugere a palavra reservada correta na mensagem de erro. Esse recurso ajuda os programadores a identificar e corrigir rapidamente erros comuns de digitação. Por exemplo:
>>> whille True: ... pass Traceback (most recent call last): File "<stdin>", line 1 whille True: ^^^^^^ SyntaxError: invalid syntax. Did you mean 'while'? >>> asynch def fetch_data(): ... pass Traceback (most recent call last): File "<stdin>", line 1 asynch def fetch_data(): ^^^^^^ SyntaxError: invalid syntax. Did you mean 'async'? >>> async def foo(): ... awaid fetch_data() Traceback (most recent call last): File "<stdin>", line 2 awaid fetch_data() ^^^^^ SyntaxError: invalid syntax. Did you mean 'await'? >>> raisee ValueError("Error") Traceback (most recent call last): File "<stdin>", line 1 raisee ValueError("Error") ^^^^^^ SyntaxError: invalid syntax. Did you mean 'raise'?
Embora o recurso se concentre nos casos mais comuns, algumas variações de erros ortográficos ainda podem resultar em erros de sintaxe comuns. (Contribuição de Pablo Galindo em gh-132449.)
Quando uma atribuição de desempacotamento falha devido a um número incorreto de variáveis, a mensagem de erro exibe o número de valores recebidos em mais casos do que antes. (Contribuição de Tushar Sadhwani em gh-122239.)
>>> x, y, z = 1, 2, 3, 4 Traceback (most recent call last): File "<stdin>", line 1, in <module> x, y, z = 1, 2, 3, 4 ^^^^^^^ ValueError: too many values to unpack (expected 3, got 4)
Instruções
elif
que seguem um blocoelse
agora têm uma mensagem de erro específica. (Contribuição de Steele Farnsworth em gh-129902.)>>> if who == "eu": ... print("Sou eu!") ... else: ... print("Não sou eu!") ... elif who is None: ... print("Quem é?") File "<stdin>", line 5 elif who is None: ^^^^ SyntaxError: 'elif' block follows an 'else' block
Se uma instrução (
pass
,del
,return
,yield
,raise
,break
,continue
,assert
,import
,from
) for passada para Expressões condicionais apóselse
, ou uma dentrepass
,break
oucontinue
for passada antes deif
, a mensagem de erro destacará onde aexpressão
é necessária. (Contribuição de Sergey Miryanov em gh-129515.)>>> x = 1 if True else pass Traceback (most recent call last): File "<string>", line 1 x = 1 if True else pass ^^^^ SyntaxError: expected expression after 'else', but statement is given >>> x = continue if True else break Traceback (most recent call last): File "<string>", line 1 x = continue if True else break ^^^^^^^^ SyntaxError: expected expression before 'if', but statement is given
Quando strings fechadas incorretamente são detectadas, a mensagem de erro sugere que pode ser que a intenção era a string ser parte da string. (Contribuição de Pablo Galindo em gh-88535.)
>>> "O objeto interessante "O objeto interessante" é muito importante" Traceback (most recent call last): SyntaxError: invalid syntax. Is this intended to be part of the string?
Quando strings têm prefixos incompatíveis, o erro agora mostra quais prefixos são incompatíveis. (Contribuição de Nikita Sobolev em gh-133197.)
>>> ub'abc' File "<python-input-0>", line 1 ub'abc' ^^ SyntaxError: 'u' and 'b' prefixes are incompatible
Mensagens de erro aprimoradas ao usar
as
com alvos incompatíveis em:Importações:
import ... as ...
Importações “from”:
from ... import ... as ...
Manipuladores “except”:
except ... as ...
Casos de correspondência de padrão:
case ... as ...
(Contribuição de Nikita Sobolev in gh-123539, gh-123562 e gh-123440.)
>>> import ast as arr[0] File "<python-input-1>", line 1 import ast as arr[0] ^^^^^^ SyntaxError: cannot use subscript as import target
Mensagem de erro aprimorada ao tentar adicionar uma instância de um tipo não-hasheável a um
dict
ouset
. (Contribuição de CF Bolz-Tereick e Victor Stinner em gh-132828.)>>> s = set() >>> s.add({'pages': 12, 'grade': 'A'}) Traceback (most recent call last): File "<python-input-1>", line 1, in <module> s.add({'pages': 12, 'grade': 'A'}) ~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ TypeError: cannot use 'dict' as a set element (unhashable type: 'dict') >>> d = {} >>> l = [1, 2, 3] >>> d[l] = 12 Traceback (most recent call last): File "<python-input-4>", line 1, in <module> d[l] = 12 ~^^^ TypeError: cannot use 'list' as a dict key (unhashable type: 'list')
PEP 741: API C de configuração do Python¶
Adiciona uma PyInitConfig API C para configurar a inicialização do Python sem depender de estruturas C e a capacidade de fazer alterações compatíveis com ABI no futuro.
Conclui a API C PyConfig da PEP 587 adicionando PyInitConfig_AddModule()
que pode ser usado para adicionar um módulo de extensão embutido; um recurso anteriormente chamado de “inittab”.
Adiciona as funções PyConfig_Get()
e PyConfig_Set()
para obter e definir a configuração de tempo de execução atual.
A “Configuração de Inicialização do Python” da PEP 587 unificou todas as maneiras de configurar a inicialização do Python. Esta PEP também unifica a configuração da pré-inicialização do Python e a inicialização do Python em uma única API. Além disso, esta PEP oferece apenas uma opção para incorporar o Python, em vez de ter duas opções, “Python” e “Isolated” (PEP 587), simplificando ainda mais a API.
A API PyConfig da PEP 587 de nível inferior permanece disponível para casos de uso com um nível intencionalmente mais alto de acoplamento aos detalhes de implementação do CPython (como emular a funcionalidade completa da CLI do CPython, incluindo seus mecanismos de configuração).
(Contribuição de Victor Stinner em gh-107954.)
Ver também
Capacidades de introspecção assíncrona¶
Foi adicionada uma nova interface de linha de comando para inspecionar processos Python em execução usando tarefas assíncronas, disponível via:
python -m asyncio ps PID
Esta ferramenta inspeciona o ID do processo (PID) fornecido e exibe informações sobre as tarefas assíncronas em execução. Ela gera uma tabela de tarefas: uma lista simples de todas as tarefas, seus nomes, suas pilhas de corrotinas e quais tarefas as aguardam.
python -m asyncio pstree PID
Esta ferramenta busca as mesmas informações, mas renderiza uma árvore de chamadas assíncrona visual, mostrando os relacionamentos das corrotinas em um formato hierárquico. Este comando é particularmente útil para depurar programas assíncronos de longa duração ou travados. Ele pode ajudar os desenvolvedores a identificar rapidamente onde um programa está bloqueado, quais tarefas estão pendentes e como as corrotinas estão encadeadas.
Por exemplo, dado este código:
import asyncio
async def play(track):
await asyncio.sleep(5)
print(f"🎵 Finished: {track}")
async def album(name, tracks):
async with asyncio.TaskGroup() as tg:
for track in tracks:
tg.create_task(play(track), name=track)
async def main():
async with asyncio.TaskGroup() as tg:
tg.create_task(
album("Sundowning", ["TNDNBTG", "Levitate"]), name="Sundowning")
tg.create_task(
album("TMBTE", ["DYWTYLM", "Aqua Regia"]), name="TMBTE")
if __name__ == "__main__":
asyncio.run(main())
Executar a nova ferramenta no processo em execução produzirá uma tabela como esta:
python -m asyncio ps 12345
tid task id task name coroutine stack awaiter chain awaiter name awaiter id
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
1935500 0x7fc930c18050 Task-1 TaskGroup._aexit -> TaskGroup.__aexit__ -> main 0x0
1935500 0x7fc930c18230 Sundowning TaskGroup._aexit -> TaskGroup.__aexit__ -> album TaskGroup._aexit -> TaskGroup.__aexit__ -> main Task-1 0x7fc930c18050
1935500 0x7fc93173fa50 TMBTE TaskGroup._aexit -> TaskGroup.__aexit__ -> album TaskGroup._aexit -> TaskGroup.__aexit__ -> main Task-1 0x7fc930c18050
1935500 0x7fc93173fdf0 TNDNBTG sleep -> play TaskGroup._aexit -> TaskGroup.__aexit__ -> album Sundowning 0x7fc930c18230
1935500 0x7fc930d32510 Levitate sleep -> play TaskGroup._aexit -> TaskGroup.__aexit__ -> album Sundowning 0x7fc930c18230
1935500 0x7fc930d32890 DYWTYLM sleep -> play TaskGroup._aexit -> TaskGroup.__aexit__ -> album TMBTE 0x7fc93173fa50
1935500 0x7fc93161ec30 Aqua Regia sleep -> play TaskGroup._aexit -> TaskGroup.__aexit__ -> album TMBTE 0x7fc93173fa50
ou uma árvore como esta:
python -m asyncio pstree 12345
└── (T) Task-1
└── main example.py:13
└── TaskGroup.__aexit__ Lib/asyncio/taskgroups.py:72
└── TaskGroup._aexit Lib/asyncio/taskgroups.py:121
├── (T) Sundowning
│ └── album example.py:8
│ └── TaskGroup.__aexit__ Lib/asyncio/taskgroups.py:72
│ └── TaskGroup._aexit Lib/asyncio/taskgroups.py:121
│ ├── (T) TNDNBTG
│ │ └── play example.py:4
│ │ └── sleep Lib/asyncio/tasks.py:702
│ └── (T) Levitate
│ └── play example.py:4
│ └── sleep Lib/asyncio/tasks.py:702
└── (T) TMBTE
└── album example.py:8
└── TaskGroup.__aexit__ Lib/asyncio/taskgroups.py:72
└── TaskGroup._aexit Lib/asyncio/taskgroups.py:121
├── (T) DYWTYLM
│ └── play example.py:4
│ └── sleep Lib/asyncio/tasks.py:702
└── (T) Aqua Regia
└── play example.py:4
└── sleep Lib/asyncio/tasks.py:702
Se um ciclo for detectado no grafo async await (o que pode indicar um problema de programação), a ferramenta levanta um erro e lista os caminhos de ciclo que impedem a construção da árvore:
python -m asyncio pstree 12345
ERROR: await-graph contains cycles - cannot print a tree!
cycle: Task-2 → Task-3 → Task-2
(Contribuição de Pablo Galindo, Łukasz Langa, Yury Selivanov e Marta Gomez Macias em gh-91048.)
Um novo tipo de interpretador¶
Um novo tipo de interpretador foi adicionado ao CPython. Ele utiliza chamadas de cauda entre pequenas funções C que implementam opcodes Python individuais, em vez de uma única instrução case C extensa. Para alguns compiladores mais recentes, este interpretador oferece desempenho significativamente melhor. Dados preliminares em nossas máquinas sugerem um código Python até 30% mais rápido e uma média geométrica de 3 a 5% mais rápido no pyperformance
, dependendo da plataforma e da arquitetura. A linha de base é o Python 3.14, construído com o Clang 19 sem este novo interpretador.
Atualmente, este interpretador funciona apenas com o Clang 19 e versões mais recentes em arquiteturas x86-64 e AArch64. No entanto, esperamos que uma versão futura do GCC também ofereça suporte a ele.
Este recurso é opcional por enquanto. Recomendamos fortemente habilitar a otimização guiada por perfil com o novo interpretador, pois é a única configuração que testamos e podemos validar seu desempenho aprimorado. Para mais informações sobre como construir Python, consulte --with-tail-call-interp
.
Nota
Isso não deve ser confundido com a otimização de chamada de cauda de funções Python, que atualmente não está implementada no CPython.
Este novo tipo de interpretador é um detalhe de implementação interna do interpretador CPython. Ele não altera em nada o comportamento visível dos programas Python. Pode melhorar o desempenho deles, mas não altera nada mais.
Atenção
Esta seção relatou anteriormente um aumento de velocidade médio geométrico de 9 a 15%. Desde então, esse número foi cuidadosamente revisado reduzindo para 3 a 5%. Embora esperemos que os resultados de desempenho sejam melhores do que os relatados, nossas estimativas são mais conservadoras devido a um bug do compilador encontrado no Clang/LLVM 19, que faz com que o interpretador normal seja mais lento. Não tínhamos conhecimento desse bug, resultando em resultados imprecisos. Pedimos sinceras desculpas por comunicar resultados que eram precisos apenas para o LLVM v19.1.x e v20.1.0. Neste meio-tempo, o bug foi corrigido no LLVM v20.1.1 e para o próximo v21.1, mas permanecerá sem correção para o LLVM v19.1.x e v20.1.0. Portanto, quaisquer benchmarks com essas versões do LLVM podem produzir números imprecisos. (Agradecimentos a Nelson Elhage por trazer isso à tona.)
(Contribuição de Ken Jin em gh-128563, com ideias sobre como implementar isso em CPython por Mark Shannon, Garrett Gu, Haoran Xu e Josh Haberman.)
Modo de threads livres¶
O modo de threads livres (PEP 703), adicionado inicialmente na versão 3.13, foi significativamente aprimorado. A implementação descrita no PEP 703 foi concluída, incluindo alterações na API C, e soluções temporárias no interpretador foram substituídas por soluções mais permanentes. O interpretador adaptativo especializado (PEP 659) agora está habilitado no modo de threads livres, o que, juntamente com muitas outras otimizações, melhora significativamente seu desempenho. A perda de desempenho em código de thread única no modo de threads livres agora é de aproximadamente 5 a 10%, dependendo da plataforma e do compilador C utilizados.
Este trabalho foi realizado por muitos colaboradores: Sam Gross, Matt Page, Neil Schemenauer, Thomas Wouters, Donghee Na, Kirill Podoprigora, Ken Jin, Itamar Oren, Brett Simmers, Dino Viehland, Nathan Goldbaum, Ralf Gommers, Lysandros Nikolaou, Kumar Aditya, Edgar Margffoy e muitos outros.
Alguns desses colaboradores são empregados da Meta, que continuou a fornecer recursos de engenharia significativos para dar suporte a este projeto.
A partir da versão 3.14, ao compilar módulos de extensão para a construção do CPython com threads livres no Windows, a variável de pré-processador Py_GIL_DISABLED
agora precisa ser especificada pelo backend de construção, pois não será mais determinada automaticamente pelo compilador C. Para um interpretador em execução, a configuração usada em tempo de compilação pode ser encontrada usando sysconfig.get_config_var()
.
Um novo sinalizador foi adicionado, context_aware_warnings
. Este sinalizador assume como padrão true para a construção com threads livres e false para a construção com GIL habilitada. Se o sinalizador for true, o gerenciador de contexto warnings.catch_warnings
usa uma variável de contexto para filtros de aviso. Isso faz com que o gerenciador de contexto se comporte de forma previsível quando usado com múltiplas threads ou tarefas assíncronas.
Um novo sinalizador foi adicionado, thread_inherit_context
. Esta flag assume como padrão true para a construção com threads livres e false para a construção com GIL habilitada. Se o sinalizador for true, as threads criadas com threading.Thread
iniciam com uma cópia de Context()
do chamador de start()
. Mais significativamente, isso faz com que o contexto de filtragem de avisos estabelecido por catch_warnings
seja “herdado” por threads (ou tarefas assíncronas) iniciadas nesse contexto. Também afeta outros módulos que usam variáveis de contexto, como o gerenciador de contexto decimal
.
Realce de sintaxe no PyREPL¶
O console interativo padrão agora realça a sintaxe do Python à medida que você digita. O recurso está ativado por padrão, a menos que a variável de ambiente PYTHON_BASIC_REPL
esteja configurado ou que qualquer variável de ambiente de desativação de cor seja usada. Consulte Controlando cores para obter detalhes.
O tema de cores padrão para realce de sintaxe busca um bom contraste e usa exclusivamente os códigos de cores ANSI padrão VGA de 4 bits para obter a máxima compatibilidade. O tema pode ser personalizado com o uso de uma API experimental _colorize.set_theme()
. Isso pode ser chamado interativamente, bem como no script PYTHONSTARTUP
.
(Contribuição de Łukasz Langa em gh-131507.)
Versões binárias para o compilador experimental just-in-time¶
Os binários oficiais de lançamento para macOS e Windows agora incluem um compilador JIT (just-in-time) experimental. Embora não seja recomendado para uso em produção, ele pode ser testado definindo PYTHON_JIT=1
como uma variável de ambiente. Construções de código-fonte downstream e redistribuidores podem usar a opção de configuração --enable-experimental-jit=yes-off
para obter um comportamento semelhante.
O JIT está em estágio inicial e ainda em desenvolvimento ativo. Portanto, o impacto típico de sua ativação no desempenho pode variar de 10% mais lento a 20% mais rápido, dependendo da carga de trabalho. Para auxiliar nos testes e na avaliação, um conjunto de funções de introspecção foi fornecido no espaço de nomes sys._jit
. sys._jit.is_available()
pode ser usado para determinar se o executável atual oferece suporte a compilação JIT, enquanto sys._jit.is_enabled()
pode ser usado para informar se a compilação JIT foi ativada para o processo atual.
Atualmente, a funcionalidade ausente mais significativa é que depuradores e profilers nativos, como gdb
e perf
, não conseguem desenrolar quadros JIT (depuradores e profilers Python, como pdb
ou profile
, continuam funcionando sem modificações). Construções com threads livres não oferecem suporte a compilação JIT.
Por favor, relate quaisquer bugs ou grandes regressões de desempenho que você encontrar!
Ver também
Controle de avisos seguros simultâneos¶
O gerenciador de contexto warnings.catch_warnings
agora usará opcionalmente uma variável de contexto para filtros de aviso. Isso é habilitado definindo o sinalizador context_aware_warnings
, seja com a opção de linha de comando -X
ou com uma variável de ambiente. Isso fornece controle previsível de avisos ao usar catch_warnings
combinado com múltiplas threads ou tarefas assíncronas. O sinalizador padrão é true para a construção com threads livres e false para a construção com GIL habilitada.
(Contribuição de Neil Schemenauer e Kumar Aditya em gh-130010.)
Coleta de lixo incremental¶
O coletor de lixo cíclico agora é incremental. Isso significa que os tempos máximos de pausa são reduzidos em uma ordem de magnitude ou mais para heaps maiores.
Agora existem apenas duas gerações: jovem e velha. Quando gc.collect()
não é chamado diretamente, o coletor de lixo é invocado com um pouco menos de frequência. Quando invocado, ele coleta a geração jovem e um incremento da geração antiga, em vez de coletar uma ou mais gerações.
O comportamento de gc.collect()
muda ligeiramente:
gc.collect(1)
: Executa um incremento da coleta de lixo, em vez de coletar a geração 1.Outras chamadas para
gc.collect()
não foram alteradas.
(Contribuição de Mark Shannon em gh-108362.)
Suporte a plataforma¶
PEP 776: O Emscripten agora é uma plataforma oficialmente suportada no nível 3. Como parte desse esforço, mais de 25 bugs na libc do Emscripten foram corrigidos. O Emscripten agora inclui suporte para
ctypes
,termios
efcntl
, bem como suporte experimental para PyREPL.(Contribuição de R. Hood Chatham in gh-127146, gh-127683 e gh-136931.)
Outras mudanças de linguagem¶
O shell padrão interativo agora oferece suporte ao preenchimento automático de importação. Isso significa que digitar
import foo
e pressionar<tab>
sugerirá módulos que começam comfoo
. Da mesma forma, digitarfrom foo import b
sugerirá submódulos defoo
que começam comb
. Observe que o preenchimento automático de atributos de módulo não é suportado atualmente. (Contribuição de Tomas Roun em gh-69605.)O
map()
embutido agora possui um sinalizador somente-nomeado opcional strict, comozip()
, para verificar se todos os iteráveis têm o mesmo comprimento. (Contribuição de Wannes Boeykens em gh-119793.)O uso incorreto de
await
e compreensões assíncronas agora é detectado mesmo que o código seja otimizado pela opção de linha de comando-O
. Por exemplo,python -O -c 'assert await 1'
agora produz umSyntaxError
. (Contribuição de Jelle Zijlstra em gh-121637.)Escritas em
__debug__
agora são detectadas mesmo que o código seja otimizado pela opção de linha de comando-O
. Por exemplo,python -O -c 'assert (__debug__ := 1)'
agora produz umSyntaxError
. (Contribuição de Irit Katriel em gh-122245.)Adiciona os métodos de classe
float.from_number()
ecomplex.from_number()
para converter um número para o tipofloat
oucomplex
, respectivamente. Eles levantam um erro se o argumento for uma string. (Contribuição de Serhiy Storchaka em gh-84978.)Implementa regras aritméticas de modo misto combinando números reais e complexos, conforme especificado pelos padrões C desde C99. (Contribuição de Sergey B Kirpichev em gh-69639.)
Todas as páginas de código do Windows agora são suportadas como codecs “cpXXX” no Windows. (Contribuição de Serhiy Storchaka em gh-123803.)
Os objetos
super
agora sãoserializáveis com pickle
ecopiáveis
. (Contribuição de Serhiy Storchaka em gh-125767.)O tipo
memoryview
agora oferece suporte a subscrição, tornando-o um tipo genérico. (Contribuição de Brian Schubert em gh-126012.)Suporte para sublinhado e vírgula como separadores de milhares na parte fracionária para tipos de apresentação de ponto flutuante do novo estilo de formatação de string (com
format()
ou Literais de strings formatadas). (Contribuição de Sergey B Kirpichev em gh-87790.)Os métodos
bytes.fromhex()
ebytearray.fromhex()
agora aceitam objetos ASCIIbytes
e similares. (Contribuição de Daniel Pope em gh-129349.)Suporte a
\z
como sinônimo de\Z
emexpressões regulares
. É interpretado sem ambiguidade em muitos outros mecanismos de expressão regular, ao contrário de\Z
, que tem um comportamento ligeiramente diferente. (Contribuição de Serhiy Storchaka em gh-133306.)\B
emexpressão regular
agora corresponde a uma string de entrada vazia. Agora é sempre o oposto de\b
. (Contribuição de Serhiy Storchaka em gh-124130.)Aplicações iOS e macOS agora podem ser configurados para redirecionar o conteúdo
stdout
estderr
para o log do sistema. (Contribuição de Russell Keith-Magee em gh-127592.)O ambiente de teste do iOS agora pode transmitir a saída do teste enquanto ele está em execução. O ambiente de teste também pode ser usado para executar o conjunto de testes de outros projetos além do CPython. (Contribuição de Russell Keith-Magee em gh-127592.)
pow()
de três argumentos agora tenta chamar__rpow__()
se necessário. Anteriormente, ele só era chamado empow()
de dois argumentos e no operador binário de potência. (Contribuição de Serhiy Storchaka em gh-130104.)Adiciona uma implementação embutido para HMAC (RFC 2104) usando código formalmente verificado do projeto HACL*. Esta implementação é usada como fallback quando a implementação OpenSSL do HMAC não está disponível. (Contribuição de Bénédikt Tran em gh-99108.)
O sinalizador de tempo de importação agora pode rastrear módulos já carregados (‘em cache’), por meio da nova opção
-X importtime=2
. Quando um módulo desse tipo é importado, os temposself
ecumulative
são substituídos pela stringcached
. Valores acima de2
para-X importtime
agora são reservados para uso futuro. (Contribuição de Noah Kim e Adam Turner em gh-118655.)Ao criar uma subclasse de um tipo C puro, os slots C para o novo tipo não são mais substituídos por uma versão encapsulada na criação da classe, caso não sejam explicitamente substituídos na subclasse. (Contribuição de Tomasz Pytel em gh-132329.)
A opção de linha de comando
-c
agora recua automaticamente seu argumento de código antes da execução. O comportamento de dedentação automática espelhatextwrap.dedent()
. (Contribuição de Jon Crall e Steven Sun em gh-103998.)Melhoria na mensagem de erro quando um objeto que oferece suporte ao protocolo do gerenciador de contexto síncrono é inserido usando
async with
em vez dewith
. E vice-versa com o protocolo do gerenciador de contexto assíncrono. (Contribuição de Bénédikt Tran em gh-128398.)-J
não é mais um sinalizador reservado para Jython e agora não tem nenhum significado especial. (Contribuição de Adam Turner em gh-133336.)O
int()
embutido não delega mais para__trunc__()
. Classes que desejam oferecer suporte a conversão paraint()
devem implementar__int__()
ou__index__()
. (Contribuição de Mark Dickinson em gh-119743.)Usa
NotImplemented
em um contexto booleano agora levantaráTypeError
. Isso levantaDeprecationWarning
desde o Python 3.9. (Contribuição de Jelle Zijlstra em gh-118767.)
PEP 765: não permitir return
/break
/continue
que saia de um bloco finally
¶
O compilador emite uma SyntaxWarning
quando uma instrução return
, break
ou continue
aparece onde sai de um bloco finally
. Essa alteração é especificada na PEP 765.
Novos módulos¶
annotationlib
: Para introspecção de anotações. Veja PEP 749 para mais detalhes. (Contribuição de Jelle Zijlstra em gh-119180.)
Módulos melhorados¶
argparse¶
O valor padrão do nome do programa para
argparse.ArgumentParser
agora reflete a maneira como o interpretador Python foi instruído a encontrar o código do módulo__main__
. (Contribuição de Serhiy Storchaka e Alyssa Coghlan em gh-66436.)Foi introduzido o parâmetro opcional suggest_on_error em
argparse.ArgumentParser
, permitindo sugestões para escolhas de argumentos e nomes de subanalisadores caso sejam digitados incorretamente pelo usuário. (Contribuição de Savannah Ostrowski em gh-124456.)Habilita a cor do texto de ajuda, que pode ser desabilitada com o parâmetro opcional color em
argparse.ArgumentParser
. Isso também pode ser controlado por variáveis de ambiente. (Contribuição de Hugo van Kemenade em gh-130645.)
ast¶
Adiciona
ast.compare()
para comparar dois ASTs. (Contribuição de Batuhan Taskaya e Jeremy Hylton em gh-60191.)Adiciona suporte para
copy.replace()
para nós AST. (Contribuição de Bénédikt Tran em gh-121141.)Docstrings agora são removidas de um AST otimizado no nível de otimização 2. (Contribuição de Irit Katriel em gh-123958.)
A saída
repr()
para nós AST agora inclui mais informações. (Contribuição de Tomas Roun em gh-116022.)ast.parse()
, quando chamado com um AST como entrada, agora sempre verifica se o tipo de nó raiz é apropriado. (Contribuição de Irit Katriel em gh-130139.)Adiciona as novas opções
--feature-version
,--optimize
e--show-empty
à interface de linha de comando. (Contribuição de Semyon Moroz em gh-133367.)
asyncio¶
A função e os métodos denominados
create_task()
agora aceitam uma lista arbitrária de argumentos nomeados. Todos os argumentos nomeados são passados para o construtorTask
ou para a fábrica de tarefas personalizada. (Consulteset_task_factory()
para obter detalhes.) Os argumentos nomeadosname
econtext
não são mais especiais; o nome agora deve ser definido usando o argumento nomeadosname
da fábrica, econtext
pode serNone
.Isso afeta as seguintes funções e métodos:
asyncio.create_task()
,asyncio.loop.create_task()
,asyncio.TaskGroup.create_task()
. (Contribuição de Thomas Grainger em gh-128307.)Há duas novas funções utilitárias para introspecção e impressão do gráfico de chamadas de um programa:
capture_call_graph()
eprint_call_graph()
. (Contribuição de Yury Selivanov, Pablo Galindo Salgado e Łukasz Langa em gh-91048.)
calendar¶
Por padrão, a data de hoje é destacada em cores na saída de texto da linha de comando do
calendar
. Isso pode ser controlado pelas variáveis de ambiente. (Contribuição de Hugo van Kemenade em gh-128317.)
concurrent.futures¶
Adiciona
InterpreterPoolExecutor
, que expõe “subinterpretadores” (vários interpretadores Python no mesmo processo) ao código Python. Isso é separado da API proposta na PEP 734. (Contribuição de Eric Snow em gh-124548.)
O método
ProcessPoolExecutor
método de início padrão foi alterado de fork para forkserver em plataformas diferentes de macOS e Windows, onde já era spawn.Se o método fork incompatível com threading for necessário, você deverá solicitá-lo explicitamente fornecendo um contexto de multiprocessamento mp_context para
ProcessPoolExecutor
.Veja as restrições de forkserver para obter informações e diferenças com o método fork e como essa alteração pode afetar o código existente com variáveis globais compartilhadas mutáveis e/ou objetos compartilhados que não podem ser automaticamente
serializadas com pickle
.(Contribuição de Gregory P. Smith em gh-84559.)
Adiciona
concurrent.futures.ProcessPoolExecutor.terminate_workers()
econcurrent.futures.ProcessPoolExecutor.kill_workers()
como formas de encerrar ou eliminar todos os processos de trabalho ativos no pool fornecido. (Contribuição de Charles Machalow em gh-130849.)Adiciona o parâmetro opcional
buffersize
aconcurrent.futures.Executor.map()
para limitar o número de tarefas enviadas cujos resultados ainda não foram gerados. Se o buffer estiver cheio, a iteração sobre os iteráveis será pausada até que um resultado seja produzido pelo buffer. (Contribuição de Enzo Bonnal e Josh Rosenberg em gh-74028.)
configparser¶
Correção de segurança: não gravará mais arquivos de configuração que não consegue ler. Tentar usar
configparser.ConfigParser.write()
em chaves contendo delimitadores ou começando com o padrão de cabeçalho de seção levantará umconfigparser.InvalidWriteError
. (Contribuição de Jacob Lincoln em gh-129270.)
contextvars¶
Adiciona suporte ao protocolo do gerenciador de contexto por
contextvars.Token
. (Contribuição de Andrew Svetlov em gh-129889.)
ctypes¶
O layout dos campos de bit em
Structure
eUnion
agora corresponde mais fielmente aos padrões da plataforma (GCC/Clang ou MSVC). Em particular, os campos não se sobrepõem mais. (Contribuição de Matthias Görgens em gh-97702.)O atributo de classe
Structure._layout_
agora pode ser definido para ajudar a corresponder a uma ABI não padrão. (Contribuição de Petr Viktorin em gh-97702.)A classe de descritores de campo
Structure
/Union
agora está disponível comoCField
e possui novos atributos para auxiliar na depuração e na introspecção. (Contribuição de Petr Viktorin em gh-128715.)No Windows, a exceção
COMError
agora é pública. (Contribuição de Jun Komoda em gh-126686.)No Windows, a função
CopyComPointer()
agora é pública. (Contribuição de Jun Komoda em gh-127275.)ctypes.memoryview_at()
agora existe para criar um objetomemoryview
que se refere ao ponteiro e comprimento fornecidos. Isso funciona comoctypes.string_at()
, exceto que evita uma cópia de buffer e é normalmente útil ao implementar funções de retorno de chamada Python puras que recebem buffers de tamanho dinâmico. (Contribuição de Rian Hunter em gh-112018.)Tipos complexos,
c_float_complex
,c_double_complex
ec_longdouble_complex
, agora estão disponíveis se tanto o compilador quanto a bibliotecalibffi
oferecerem suporte a tipos C complexos. (Contribuição de Sergey B Kirpichev em gh-61103.)Adiciona
ctypes.util.dllist()
para listar as bibliotecas compartilhadas carregadas pelo processo atual. (Contribuição de Brian Ward em gh-119349.)Move o cache de tipos
ctypes.POINTER()
de um cache interno global (_pointer_type_cache
) para o atributoctypes._CData.__pointer_type__
dos tiposctypes
correspondentes. Isso impedirá que o cache cresça sem limites em algumas situações. (Contribuição de Sergey Miryanov em gh-100926.)O tipo
ctypes.py_object
agora oferece suporte a subscrição, tornando-o um tipo genérico. (Contribuição de Brian Schubert em gh-132168.)ctypes
agora oferece suporte a construções com threads livres. (Contribuição de Kumar Aditya e Peter Bierma em gh-127945.)
curses¶
Adiciona a função
assume_default_colors()
, um refinamento da funçãouse_default_colors()
que permite alterar o par de cores0
. (Contribuição de Serhiy Storchaka em gh-133139.)
datetime¶
Adiciona
datetime.time.strptime()
edatetime.date.strptime()
. (Contribuição de Wannes Boeykens em gh-41431.)
decimal¶
Adiciona o construtor alternativo
Decimal
Decimal.from_number()
. (Contribuição de Serhiy Storchaka em gh-121798.)Expõe
decimal.IEEEContext()
para oferecer suporte à criação de contextos correspondentes aos formatos de intercâmbio decimal do IEEE 754 (2008). (Contribuição de Sergey B Kirpichev em gh-53032.)
difflib¶
Páginas de comparação com alterações destacadas geradas pela classe
difflib.HtmlDiff
agora oferecem suporte ao modo escuro. (Contribuição de Jiahao Li em gh-129939.)
dis¶
Adiciona suporte para renderizar informações completas sobre o local da fonte de
instruções
, em vez de apenas o número da linha. Este recurso é adicionado às seguintes interfaces por meio do argumento nomeado show_positions:Esse recurso também é exposto via
dis --show-positions
. (Contribuição de Bénédikt Tran em gh-123165.)Adiciona a opção de linha de comando
dis --specialized
para mostrar o bytecode especializado. (Contribuição de Bénédikt Tran em gh-127413.)
errno¶
Adiciona o código de erro
errno.EHWPOISON
. (Contribuição de James Roy em gh-126585.)
faulthandler¶
Adiciona suporte para exibir o stack trace (situação da pilha de execução) C em sistemas que o suportam via
faulthandler.dump_c_stack()
ou via o argumento c_stack emfaulthandler.enable()
. (Contribuição de Peter Bierma em gh-127604.)
fnmatch¶
Adicionada
fnmatch.filterfalse()
para excluir nomes que correspondem a um padrão. (Contribuição de Bénédikt Tran em gh-74598.)
fractions¶
Adiciona suporte para converter qualquer objeto que tenha o método
as_integer_ratio()
em umaFraction
. (Contribuição de Serhiy Storchaka em gh-82017.)Adiciona o construtor alternativo
Fraction.from_number()
paraFraction
. (Contribuição de Serhiy Storchaka in gh-121797.)
functools¶
Adiciona suporte a sentinelas
functools.PlaceHolder
emfunctools.partial()
efunctools.partialmethod()
para reservar um lugar para argumento posicional. (Contribuição de Dominykas Grigonis em gh-119127.)Permite que o parâmetro inicial de
functools.reduce()
seja passado como um argumento nomeado. (Contribuição de Sayandip Dutta em gh-125916.)
getopt¶
getpass¶
Suporte a feedback do teclado pelo
getpass.getpass()
por meio do argumento opcional somente-nomeadoecho_char
. Espaços reservados para caracteres são renderizados sempre que um caractere é inserido e removidos quando um caractere é excluído. (Contribuição de Semyon Moroz em gh-77065.)
graphlib¶
Permite que
graphlib.TopologicalSorter.prepare()
seja chamado mais de uma vez, desde que a classificação não tenha sido iniciada. (Contribuição de por Daniel Pope em gh-130914.)
heapq¶
Adiciona funções para trabalhar com max-heaps:
hmac¶
http¶
As páginas de erro e listas de diretórios geradas pelo módulo
http.server
permitem que o navegador aplique seu modo escuro padrão. (Contribuição de Yorik Hansen em gh-123430.)O módulo
http.server
agora provê suporte para HTTPS usando a classehttp.server.HTTPSServer
. Essa funcionalidade é exposta pela interface de linha de comando (python -m http.server
) por meio das seguintes opções:--tls-cert <path>
: caminho para o arquivo de certificado TLS.--tls-key <path>
: caminho opcional para o arquivo de chave privada.--tls-password-file <path>
: caminho opcional para o arquivo de senha da chave privada.
(Contribuição de Semyon Moroz em gh-85162.)
imaplib¶
Adiciona o método
IMAP4.idle()
, que implementa o comandoIDLE
do IMAP4 conforme definido em RFC 2177. (Contribuição de Forest em gh-55454.)
inspect¶
inspect.signature()
recebe um novo argumento annotation_format para controlar oannotationlib.Format
usado para representar anotações. (Contribuição de Jelle Zijlstra em gh-101552.)inspect.Signature.format()
recebe um novo argumento unquote_annotations. Se verdadeiro, string com annotations são exibidas sem as aspas ao redor. (Contribuição de Jelle Zijlstra em gh-101552.)Adiciona função
inspect.ispackage()
para determinar se um objeto é um pacote ou não. (Contribuição de Zhikang Yan em gh-125634.)
io¶
A leitura de texto de um fluxo sem bloqueio com
read
pode agora levantar umBlockingIOError
se a operação não puder imediatamente retornar bytes. (Contribuição de Giovanni Siragusa em gh-109523.)Adiciona os protocolos
io.Reader
eio.Writer
como alternativas mais simples aos pseudoprotocolostyping.IO
,typing.TextIO
etyping.BinaryIO
. (Contribuição de Sebastian Rittau em gh-127648.)
json¶
Adiciona notas para erros de serialização JSON que permitam identificar a origem do erro. (Contribuição de Serhiy Storchaka em gh-122163.)
Permite o módulo
json
ser executado como um script usando a opção-m
: python -m json. Consulte a documentação da interface de linha de comando JSON . (Contribuição de Trey Hunner em gh-122873.)Por padrão, a saída da interface de linha de comando JSON é destacada em cores. Isso pode ser controlado por variáveis de ambiente . (Contribuição de Tomas Roun em gh-131952.)
linecache¶
linecache.getline()
pode recuperar código-fonte de módulos congelados. (Contribuição de Tian Gao em gh-131638.)
logging.handlers¶
logging.handlers.QueueListener
agora implementa o protocolo de gerenciador de contexto, permitindo que ele seja usado em uma instruçãowith
. (Contribuição de Charles Machalow em gh-132106.)QueueListener.start
agora levantaRuntimeError
se o ouvinte já tiver sido iniciado. (Contribuição de Charles Machalow em gh-132106.)
math¶
Adicionadas mensagens de erro mais detalhadas para erros de domínio no módulo. (Contribuição de Charlie Zhao e Sergey B Kirpichev em gh-101410.)
mimetypes¶
Documenta a linha de comando para
mimetypes
. Agora, ele é encerrado com1
em caso de falha, em vez de0
, e2
em caso de parâmetros de linha de comando incorretos, em vez de1
. Além disso, os erros são enviados para stderr em vez de stdout, e seu texto é mais conciso. (Contribuição de Oleg Iarygin e Hugo van Kemenade em gh-93096.)Adiciona tipos MIME de RFC 8081 e da MS para fontes:
Embedded OpenType:
application/vnd.ms-fontobject
OpenType Layout (OTF)
font/otf
TrueType:
font/ttf
WOFF 1.0
font/woff
WOFF 2.0
font/woff2
(Contribuição de Sahil Prajapati e Hugo van Kemenade em gh-84852.)
Adicione os tipos MIME de RFC 9559 para estruturas de contêiner de dados audiovisuais Matroska, contendo:
áudio com nenhum vídeo:
audio/matroska
(.mka
)vídeo:
video/matroska
(.mkv
)vídeo estereoscópico:
video/matroska-3d
(.mk3d
)
(Contribuição de Hugo van Kemenade em gh-89416.)
Adiciona tipos MIME para imagens com RFCs:
RFC 1494: CCITT Group 3 (
.g3
)RFC 3362: Real-time Facsimile, T.38 (
.t38
)RFC 3745: JPEG 2000 (
.jp2
), extensão (.jpx
) e composto (.jpm
)RFC 3950: Tag Image File Format Fax eXtended, TIFF-FX (
.tfx
)RFC 4047: Flexible Image Transport System (
.fits
)RFC 7903: Enhanced Metafile (
.emf
) and Windows Metafile (.wmf
)
(Contribuição de Hugo van Kemenade em gh-85957.)
Mais alterações de tipo MIME:
RFC 2361: altera o tipo de
.avi
paravideo/vnd.avi
e de.wav
paraaudio/vnd.wave
RFC 4337: adiciona MPEG-4
audio/mp4
(.m4a
)RFC 5334: adiciona mídia Ogg (
.oga
,.ogg
e.ogx
)RFC 6713: adiciona gzip
aplication/gzip
(.gz
)RFC 9639: adiciona FLAC
audio/flac
(.flac
)Adiciona 7z
aplication/x-7z-compressed
(.7z
)Adiciona Android Package
application/vnd.android.package-archive
(.apk
) quando não for rigorosoAdiciona deb
application/x-debian-package
(.deb
)Adiciona glTF binário
model/gltf-binary
(.glb
)Adiciona glTF JSON/ASCII
model/gltf+json
(.gltf
)Adiciona M4V
video/x-m4v
(.m4v
)Adiciona PHP
application/x-httpd-php
(.php
)Adiciona RAR
application/vnd.rar
(.rar
)Adiciona RPM
application/x-rpm
(.rpm
)Adiciona STL
model/stl
(.stl
)Adiciona Windows Media Video
video/x-ms-wmv
(.wmv
)De facto: adiciona WebM
audio/webm
(.weba
)ECMA-376: adiciona tipos
.docx
,.pptx
e.xlsx
OASIS: adiciona tipos OpenDocument
.odg
,.odp
,.ods
e.odt
W3C: adiciona EPUB
application/epub+zip
(.epub
)
(Contribuição de Hugo van Kemenade em gh-129965.)
Adiciona RFC 9512
application/yaml
tipo MIME para arquivos YAML (.yaml
and.yml
). (Contribuição de Sasha “Nelie” Chernykh e Hugo van Kemenade in gh-132056.)
multiprocessing¶
O método de inicialização padrão foi alterado de fork para forkserver em plataformas diferentes de macOS e Windows, onde já era spawn.
Se o método fork incompatível com threads for necessário, você deverá solicitá-lo explicitamente com um contexto de
multiprocessing.get_context()
(preferencial) ou mudar o método padrão commultiprocessing.set_start_method()
.Veja as restrições de forkserver para obter informações e diferenças com o método fork e como essa alteração pode afetar o código existente com variáveis globais compartilhadas mutáveis e/ou objetos compartilhados que não podem ser automaticamente
serializadas com pickle
.(Contribuição de Gregory P. Smith em gh-84559.)
O método de inicialização
"forkserver"
domultiprocessing
agora autentica seu soquete de controle para evitar depender exclusivamente das permissões do sistema de arquivos para restringir quais outros processos poderiam fazer com que o forkserver gerasse workers e executasse código. (Contribuição de Gregory P. Smith em gh-97514.)Os objetos proxies de multiprocessing para os tipos list e dict ganhou métodos anteriormente ausentes:
clear()
ecopy()
para proxies delist
fromkeys()
,reversed(d)
,d | {}
,{} | d
,d |= {'b': 2}
para proxies dedict
(Contribuição de Roy Hyunjin Han em gh-103134.)
Adiciona suporte para objetos
set
compartilhado viaSyncManager.set()
. O métodoset()
emmultiprocessing.Manager()
está agora disponível. (Contribuição de Mingyu Park em gh-129949.)Adiciona
multiprocessing.Process.interrupt()
que encerra o processo filho enviandoSIGINT
. Isso permite a cláusulafinally
exibir uma stack trace (situação da pilha de execução) para o processo encerrado. (Contribuição de Artem Pulkin em gh-131913.)
operador¶
Foram adicionadas duas novas funções:
operator.is_none()
eoperator.is_not_none()
. De modo queoperator.is_none(obj)
equivale aobj is None
eoperator.is_not_none(obj)
equivale aobj is not None
. (Contribuição de Raymond Hettinger e Nico Mexis em gh-115808.)
os¶
Adiciona a função
os.reload_environ()
para atualizaros.environ
eos.environb
com alterações no ambiente feitas poros.putenv()
eos.unsetenv()
, ou feitas fora do Python no mesmo processo. (Contribuição de Victor Stinner em gh-120057.)Adiciona as constantes
SCHED_DEADLINE
eSCHED_NORMAL
ao móduloos
. (Contribuição de James Roy em gh-127688.)Adiciona a função
os.readinto()
para ler em um objeto buffer de um descritor de arquivo. (Contribuição de Cody Maloney em gh-129205.)
os.path¶
O parâmetro strict para
os.path.realpath()
aceita um novo valor,os.path.ALLOW_MISSING
. Se usado, erros diferentes deFileNotFoundError
serão levantados novamente; o caminho resultante pode estar ausente, mas estará livre de links simbólicos. (Contribuição de Petr Viktorin para CVE 2025-4517.)
pathlib¶
Adiciona métodos a
pathlib.Path
para copiar ou mover arquivos e diretórios recursivamente:copy()
copia um arquivo ou árvore de diretório para um destino.copy_into()
copia para um diretório de destino.move()
move um arquivo ou árvore de diretórios para um destino.move_into()
move para um diretório de destino.
(Contribuição de Barney Gale em gh-73991.)
Adiciona o atributo
pathlib.Path.info
, que armazena um objeto que implementa o protocolopathlib.types.PathInfo
(também novo). O objeto oferece suporte à consulta do tipo de arquivo e armazenamento em cache interno dos resultados destat()
. Objetos de caminho gerados poriterdir()
são inicializados com informações do tipo de arquivo obtidas a partir da varredura do diretório pai. (Contribuição de Barney Gale em gh-125413.)
pdb¶
Pontos de interrupção codificados diretamente no código-fonte (
breakpoint()
epdb.set_trace()
) agora reutilizam a instância mais recente dePdb
que chamaset_trace()
, em vez de criar uma nova a cada vez. Como resultado, todos os dados específicos da instância, comodisplay
ecommands
, são preservados em todos os pontos de interrupção. (Contribuição de Tian Gao em gh-121450.)Adiciona um novo argumento mode a
pdb.Pdb
. Desabilita o comandorestart
quandopdb
estiver no modoinline
. (Contribuição de Tian Gao em gh-123757.)Um prompt de confirmação será exibido quando o usuário tentar sair do comando
pdb
no modoinline
.y
,Y
,<Enter>
ouEOF
confirmarão o encerramento e chamarãosys.exit()
, em vez de executarbdb.BdbQuit
. (Contribuição de Tian Gao em gh-124704.)Pontos de interrupção em linha como
breakpoint()
oupdb.set_trace()
sempre interromperão o programa no quadro da chamada, ignorando o padrãoskip
(se houver). (Contribuição de Tian Gao em gh-130493.)<tab>
no início da linha na entrada multilinha dopdb
agora preencherá um recuo de 4 espaços, em vez de inserir um caractere\t
. (Contribuição de Tian Gao em gh-130471.)A indentação automática foi introduzida na entrada multilinha do
pdb
. Ela mantém a indentação da última linha ou insere uma indentação de 4 espaços ao detectar um novo bloco de código. (Contribuição de Tian Gao em gh-133350.)$_asynctask
foi adicionado para acessar a tarefa asyncio atual, se aplicável. (Contribuição de Tian Gao em gh-124367.)pdb.set_trace_async()
foi adicionado para oferecer suporte à depuração de corrotinas assíncronas. Instruçõesawait
são suportadas com esta função. (Contribuição de Tian Gao em gh-132576.)O código-fonte exibido em
pdb
terá a sintaxe realçada. Este recurso pode ser controlado usando os mesmos métodos do PyREPL, além do argumentocolorize
recém-adicionado depdb.Pdb
. (Contribuição de Tian Gao e Łukasz Langa em gh-133355.)
pickle¶
Define a versão do protocolo padrão no módulo
pickle
como 5. Para mais detalhes, consulte protocolos pickle.Adiciona notas para erros de serialização do Pickle que permitam identificar a origem do erro. (Contribuição de Serhiy Storchaka em gh-122213.)
platform¶
Adiciona
platform.invalidate_caches()
para invalidar os resultados armazenados em cache. (Contribuição de Bénédikt Tran em gh-122549.)
pydoc¶
socket¶
Melhora e corrige o suporte para soquetes Bluetooth.
Corrige o suporte a soquetes Bluetooth no NetBSD e no DragonFly BSD. (Contribuição de Serhiy Storchaka em gh-132429.)
Corrige o suporte para
BTPROTO_HCI
no FreeBSD. (Contribuição de Victor Stinner em gh-111178.)Adiciona suporte para
BTPROTO_SCO
no FreeBSD. (Contribuição de Serhiy Storchaka em gh-85302.)Adiciona suporte para cid e bdaddr_type no endereço para
BTPROTO_L2CAP
no FreeBSD. (Contribuição de Serhiy Storchaka em gh-132429.)Adiciona suporte para channel no endereço para
BTPROTO_HCI
no Linux. (Contribuição de Serhiy Storchaka em gh-70145.)Aceita um inteiro como endereço para
BTPROTO_HCI
no Linux. (Contribuição de Serhiy Storchaka em gh-132099.)Retorna cid em
getsockname()
paraBTPROTO_L2CAP
. (Contribuição de Serhiy Storchaka em gh-132429.)Adiciona muitas novas constantes. (Contribuição de Serhiy Storchaka em gh-132734.)
ssl¶
Indica através de
ssl.HAS_PHA
se o módulossl
oferece suporte a autenticação de cliente pós-handshake (PHA) TLSv1.3. (Contribuição de Will Childs-Klein em gh-128036.)
struct¶
symtable¶
Expõe os seguintes métodos
symtable.Symbol
:(Contribuição de Bénédikt Tran em gh-120029.)
sys¶
A função especial
sys.getobjects()
, anteriormente não documentada, que só existe em construções especializadas do Python, agora pode retornar objetos de outros interpretadores além daquele em que foi chamada.Adiciona
sys._is_immortal()
para determinar se um objeto é imortal. (Contribuição de Peter Bierma em gh-128509.)No FreeBSD,
sys.platform
não contém mais a versão principal. É sempre'freebsd'
, em vez de'freebsd13'
ou'freebsd14'
.Levanta
DeprecationWarning
parasys._clear_type_cache()
. Esta função foi descontinuada no Python 3.13, mas não levantava um aviso em tempo de execução.
sys.monitoring¶
Dois novos eventos foram adicionados:
BRANCH_LEFT
eBRANCH_RIGHT
. O eventoBRANCH
está descontinuado.
sysconfig¶
Adiciona a chave
ABIFLAGS
asysconfig.get_config_vars()
no Windows. (Contribuição de Xuehai Pan em gh-131799.)
tarfile¶
data_filter()
agora normaliza alvos de links simbólicos para evitar ataques de travessia de caminho. (Contribuição de Petr Viktorin em gh-127987 e CVE 2025-4138.)extractall()
agora ignora a correção de atributos de diretório quando um diretório é removido ou substituído por outro tipo de arquivo. (Contribuição de Petr Viktorin em gh-127987 e CVE 2024-12718.)extract()
eextractall()
agora (re)aplicam o filtro de extração ao substituir um link (físico ou simbólico) por uma cópia de outro membro do arquivo e ao corrigir atributos de diretório. O primeiro levanta uma nova exceção,LinkFallbackError
. (Contribuição de Petr Viktorin para CVE 2025-4330 e CVE 2024-12718.)extract()
eextractall()
não extraem mais membros rejeitados quandoerrorlevel()
é zero. (Contribuição de Matt Prodani e Petr Viktorin em gh-112887 e CVE 2025-4435.)
threading¶
threading.Thread.start()
agora define o nome do thread do sistema operacional comothreading.Thread.name
. (Contribuição de Victor Stinner em gh-59705.)
tkinter¶
turtle¶
Adiciona gerenciadores de contexto para
turtle.fill()
,turtle.poly()
eturtle.no_animation()
. (Contribuição de Marie Roald e Yngve Mardal Moe em gh-126350.)
tipos¶
types.UnionType
agora é um apelido paratyping.Union
. Veja abaixo para mais detalhes. (Contribuição de Jelle Zijlstra em gh-105499.)
typing¶
types.UnionType
etyping.Union
agora são apelidos um do outro, o que significa que tanto as uniões no estilo antigo (criadas comUnion[int, str]
) quanto as uniões no estilo novo (int | str
) agora criam instâncias do mesmo tipo em ambiente de execução. Isso unifica o comportamento entre as duas sintaxes, mas leva a algumas diferenças de comportamento que podem afetar os usuários que inspecionam tipos em ambiente de execução:Ambas as sintaxes para criar uma união agora produzem a mesma representação de string em
repr()
. Por exemplo,repr(Union[int, str])
agora é"int | str"
em vez de"typing.Union[int, str]"
.Uniões criadas usando a sintaxe antiga não são mais armazenadas em cache. Anteriormente, executar
Union[int, str]
várias vezes retornava o mesmo objeto (Union[int, str] is Union[int, str]
seriaTrue
), mas agora retornará dois objetos diferentes. Os usuários devem usar==
para comparar uniões por igualdade, nãois
. Uniões de novo estilo nunca foram armazenadas em cache dessa forma. Essa alteração pode aumentar o uso de memória para alguns programas que usam um grande número de uniões criadas por meio do índicetyping.Union
. No entanto, vários fatores compensam esse custo: uniões usadas em anotações não são mais avaliadas por padrão no Python 3.14 devido a PEP 649; uma instância detypes.UnionType
é muito menor do que o objeto retornado porUnion[]
em versões anteriores do Python; e remover o cache também economiza espaço. Portanto, é improvável que essa alteração cause um aumento significativo no uso de memória para a maioria dos usuários.Anteriormente, as uniões antigas eram implementadas usando a classe privada
typing._UnionGenericAlias
. Essa classe não é mais necessária para a implementação, mas foi mantida para compatibilidade com versões anteriores, com remoção prevista para o Python 3.17. Os usuários devem usar auxiliares de introspecção documentados, comotyping.get_origin()
etyping.get_args()
, em vez de depender de detalhes de implementação privada.Agora é possível usar o próprio
typing.Union
em verificações deisinstance()
. Por exemplo,isinstance(int | str, typing.Union)
retornaráTrue
; anteriormente, isso levantavaTypeError
.O atributo
__args__
dos objetostyping.Union
não é mais gravável.Não é mais possível definir atributos em objetos
typing.Union
. Isso só funcionava para atributos dunder em versões anteriores, nunca foi documentado que funcionasse e apresentava falhas sutis em muitos casos.
(Contribuição de Jelle Zijlstra em gh-105499.)
typing.TypeAliasType
agora oferece suporte a desempacotamento em estrela.
unicodedata¶
O banco de dados Unicode foi atualizado para Unicode 16.0.0.
unittest¶
A saída do
unittest
agora é colorida por padrão. Isso pode ser controlado pelas variáveis de ambiente. (Contribuição de Hugo van Kemenade em gh-127221.)O Unittest Discovery suporta novamente pacote de espaço de nomes como diretório inicial. Ele foi removido no Python 3.11. (Contribuição de Jacob Walls em gh-80958.)
Vários novos métodos foram adicionados à classe
TestCase
que fornecem testes mais especializados.assertHasAttr()
eassertNotHasAttr()
verificam se o objeto tem um atributo específico.assertIsSubclass()
eassertNotIsSubclass()
verificam se o objeto é uma subclasse de uma classe específica ou de uma tupla de classes.assertStartsWith()
,assertNotStartsWith()
,assertEndsWith()
eassertNotEndsWith()
verificam se a sequência de caracteres Unicode ou de bytes começa ou termina com sequências de caracteres específicas.
(Contribuição de Serhiy Storchaka em gh-71339.)
urllib¶
Atualiza o algoritmo de autenticação de resumo HTTP para
urllib.request
, oferecendo suporte à autenticação de resumo SHA-256, conforme especificado em RFC 7616. (Contribuição de Calvin Bui em gh-128193.)Melhora a ergonomia e a conformidade com os padrões ao analisar e emitir URLs
file:
.Em
urllib.request.url2pathname()
:Aceita uma URL completa quando o novo argumento require_scheme for definido como verdadeiro.
Descarta a autoridade de URL se ela corresponder ao nome de host local.
Descarta a autoridade de URL se ela for resolvida para um endereço IP local quando o novo argumento resolve_host for definido como verdadeiro.
Descarta componentes de consulta e fragmento de URL.
Levanta
URLError
se uma autoridade de URL não for local, exceto no Windows, onde retornamos um caminho UNC como antes.
Em
urllib.request.pathname2url()
:Retorna uma URL completa quando o novo argumento add_scheme for definido como verdadeiro.
Inclui uma autoridade de URL vazia quando um caminho começar com uma barra. Por exemplo, o caminho
/etc/hosts
é convertido para a URL///etc/hosts
.
No Windows, as letras de unidade não são mais convertidas em maiúsculas, e os caracteres
:
que não seguem uma letra de unidade não causam mais o levantamento de uma exceçãoOSError
.(Contribuição de Barney Gale em gh-125866.)
uuid¶
Adiciona suporte para as versões 6, 7 e 8 do UUID via
uuid.uuid6()
,uuid.uuid7()
euuid.uuid8()
, respectivamente, conforme especificado em RFC 9562. (Contribuição de Bénédikt Tran em gh-89083.)uuid.NIL
euuid.MAX
agora estão disponíveis para representar os formatos UUID Nil e Max, conforme definido por RFC 9562. (Contribuição de Nick Pope em gh-128427.)Permite gerar vários UUIDs de uma só vez via
python -m uuid --count
. (Contribuição de Simon Legner em gh-131236.)
webbrowser¶
Os nomes na variável de ambiente
BROWSER
agora podem se referir a navegadores já registrados para o módulowebbrowser
, em vez de sempre gerar um novo comando de navegador.Isso torna possível definir
BROWSER
como o valor de um dos navegadores suportados no macOS.
zipfile¶
Adicionada
ZipInfo._for_archive
para resolver padrões adequados para um objetoZipInfo
, conforme usado porZipFile.writestr
. (Contribuição de Bénédikt Tran em gh-123424.)zipfile.ZipFile.writestr()
agora respeitaSOURCE_DATE_EPOCH
, que as distribuições podem definir centralmente e fazer com que as ferramentas de construção o consumam para produzir resultados reproduzíveis. (Contribuição de Jiahao Li em gh-91279.)
Otimizações¶
O tempo de importação para vários módulos de biblioteca padrão foi melhorado, incluindo
annotationlib
,ast
,asyncio
,base64
,cmd
,csv
,gettext
,importlib.util
,locale
,mimetypes
,optparse
,pickle
,pprint
,pstats
,shlex
,socket
,string
,subprocess
,threading
,tomllib
,types
ezipfile
.(Contribuição de Adam Turner, Bénédikt Tran, Chris Markiewicz, Eli Schwartz, Hugo van Kemenade, Jelle Zijlstra e outros em gh-118761.)
asyncio¶
Os resultados do benchmark padrão melhoraram em 10-20%, após a implementação de uma nova lista duplamente encadeada por thread para
tarefas nativas
, reduzindo também o uso de memória. Isso permite que ferramentas externas de introspecção, como python -m asyncio pstree, introspectem o grafo de chamadas de tarefas asyncio em execução em todas as threads. (Contribuição de Kumar Aditya em gh-107803.)O módulo agora conta com suporte de primeira classe para construção com threads livres. Isso permite a execução paralela de múltiplos laços de eventos em diferentes threads, com escala linear com o número de threads. (Contribuição de Kumar Aditya em gh-128002.)
base64¶
b16decode()
agora é até seis vezes mais rápido. (Contribuição de Bénédikt Tran, Chris Markiewicz e Adam Turner em gh-118761.)
bdb¶
O depurador básico agora conta com um backend baseado em
sys.monitoring
, que pode ser selecionado passando'monitoring'
para o novo parâmetro backend da classeBdb
. (Contribuição de Tian Gao em gh-124533.)
difflib¶
A função
IS_LINE_JUNK()
agora é até duas vezes mais rápida. (Contribuição de Adam Turner e Semyon Moroz em gh-130167.)
gc¶
O novo coletor de lixo incremental significa que os tempos máximos de pausa são reduzidos em uma ordem de magnitude ou mais para heaps maiores.
Devido a essa otimização, o significado dos resultados de
get_threshold()
eset_threshold()
foi alterado, juntamente comget_count()
eget_stats()
.Para retrocompatibilidade,
get_threshold()
continua retornando uma tupla de três itens. O primeiro valor é o limite para coleções novas, como antes; o segundo valor determina a taxa de varredura da coleção antiga (o padrão é 10, e valores mais altos significam que a coleção antiga é varrida mais lentamente). O terceiro valor agora não tem mais significado e é sempre zero.set_threshold()
agora ignora quaisquer itens após o segundo.get_count()
eget_stats()
continuam retornando o mesmo formato de resultados. A única diferença é que, em vez dos resultados se referirem às gerações jovem, idosa e idosa, os resultados se referem à geração jovem e aos espaços de envelhecimento e coleta da geração idosa.
Em resumo, o código que tenta manipular o comportamento do ciclo de coleta de lixo pode não funcionar exatamente como o esperado, mas é muito improvável que seja prejudicial. Todos os outros códigos funcionarão perfeitamente.
(Contribuição de Mark Shannon em gh-108362.)
io¶
pathlib¶
Path.read_bytes
agora usa o modo sem buffer para abrir arquivos, o que é entre 9% e 17% mais rápido para leitura completa. (Contribuição de Cody Maloney em gh-120754.)
pdb¶
pdb
agora suporta dois backends, baseados emsys.settrace()
ousys.monitoring
. Usar a CLI do pdb oubreakpoint()
sempre usará o backendsys.monitoring
. Instanciar explicitamentepdb.Pdb
e suas classes derivadas usará o backendsys.settrace()
por padrão, que é configurável. (Contribuição de Tian Gao em gh-124533.)
uuid¶
uuid3()
euuid5()
agora são aproximadamente 40% mais rápidos para nomes de 16 bytes e 20% mais rápidos para nomes de 1024 bytes. O desempenho para nomes mais longos permanece inalterado. (Contribuição de Bénédikt Tran em gh-128150.)uuid4()
agora é cerca de 30% mais rápido. (Contribuição de Bénédikt Tran em gh-128150.)
zlib¶
No Windows, zlib-ng agora é usado como implementação do módulo
zlib
nos binários padrão. Não há incompatibilidades conhecidas entrezlib-ng
e a implementaçãozlib
usada anteriormente. Isso deve resultar em melhor desempenho em todos os níveis de compactação.Vale ressaltar que
zlib.Z_BEST_SPEED
(1
) pode resultar em significativamente menos compressão do que a implementação anterior, além de reduzir significativamente o tempo necessário para compactar.(Contribuição de Steve Dower em gh-91349.)
Removidos¶
argparse¶
Remove os parâmetros type, choices e metavar de
BooleanOptionalAction
. Eles estão descontinuados desde o Python 3.12. (Contribuição de Nikita Sobolev em gh-118805.)Chamar
add_argument_group()
em um grupo de argumentos agora gera umValueError
. Da mesma forma,add_argument_group()
ouadd_mutually_exclusive_group()
em um grupo mutuamente exclusivo agora levantamValueError
s. Esse “aninhamento” nunca foi suportado, frequentemente não funcionava corretamente e era exposto involuntariamente por herança. Essa funcionalidade está descontinuada desde o Python 3.11. (Contribuição de Savannah Ostrowski em gh-127186.)
ast¶
Remove as seguintes classes, que são apelidos descontinuados de
Constant
desde o Python 3.8 e emitem avisos de descontinuação desde o Python 3.12:Bytes
Ellipsis
NameConstant
Num
Str
Como consequência dessas remoções, os métodos
visit_Num
,visit_Str
,visit_Bytes
,visit_NameConstant
evisit_Ellipsis
definidos pelo usuário nas subclasses personalizadasNodeVisitor
não serão mais chamados quando a subclasseNodeVisitor
estiver visitando uma AST. Em vez disso, defina um métodovisit_Constant
.(Contribuição de Alex Waygood em gh-119562.)
Remove as seguintes propriedades descontinuadas em
ast.Constant
, que estavam presentes para compatibilidade com as classes AST agora removidas:Constant.n
Constant.s
Em vez disso, use
Constant.value
. (Contribuição de Alex Waygood em gh-119562.)
asyncio¶
Remove as seguintes classes, métodos e funções, que foram descontinuados desde o Python 3.12:
AbstractChildWatcher
FastChildWatcher
MultiLoopChildWatcher
PidfdChildWatcher
SafeChildWatcher
ThreadedChildWatcher
AbstractEventLoopPolicy.get_child_watcher()
AbstractEventLoopPolicy.set_child_watcher()
get_child_watcher()
set_child_watcher()
(Contribuição de Kumar Aditya em gh-120804.)
asyncio.get_event_loop()
agora levanta umaRuntimeError
se não houver um laço de eventos atual e não cria mais implicitamente um laço de eventos.(Contribuição de Kumar Aditya em gh-126353.)
Existem alguns padrões que usam
asyncio.get_event_loop()
, a maioria deles pode ser substituída porasyncio.run()
.Se você estiver executando uma função assíncrona, basta usar
asyncio.run()
.Antes:
async def main(): ... loop = asyncio.get_event_loop() try: loop.run_until_complete(main()) finally: loop.close()
Depois:
async def main(): ... asyncio.run(main())
Se você precisar iniciar algo, por exemplo, um servidor escutando em um soquete e depois rodar para sempre, use
asyncio.run()
e umasyncio.Event
.Antes:
def start_server(loop): ... loop = asyncio.get_event_loop() try: start_server(loop) loop.run_forever() finally: loop.close()
Depois:
def start_server(loop): ... async def main(): start_server(asyncio.get_running_loop()) await asyncio.Event().wait() asyncio.run(main())
Se você precisar executar algo em um laço de eventos, execute algum código de bloqueio em torno dele, use
asyncio.Runner
.Antes:
async def operation_one(): ... def blocking_code(): ... async def operation_two(): ... loop = asyncio.get_event_loop() try: loop.run_until_complete(operation_one()) blocking_code() loop.run_until_complete(operation_two()) finally: loop.close()
Depois:
async def operation_one(): ... def blocking_code(): ... async def operation_two(): ... with asyncio.Runner() as runner: runner.run(operation_one()) blocking_code() runner.run(operation_two())
email¶
Remove o parâmetro isdst de
email.utils.localtime()
, que foi descontinuado e é ignorado desde o Python 3.12. (Contribuição de Hugo van Kemenade em gh-118798.)
importlib.abc¶
Remove classes descontinuadas
importlib.abc
:ResourceReader
(useTraversableResources
)Traversable
(useTraversable
)TraversableResources
(useTraversableResources
)
(Contribuição de Jason R. Coombs e Hugo van Kemenade em gh-93963.)
itertools¶
Remove o suporte para operações de cópia, cópia profunda e de serialização com pickle dos iteradores
itertools
. Eles emitem umDeprecationWarning
desde o Python 3.12. (Contribuição de Raymond Hettinger em gh-101588.)
pathlib¶
Remove o suporte para passagem de argumentos nomeados adicionais para
Path
. Em versões anteriores, tais argumentos eram ignorados. (Contribuição de Barney Gale em gh-74033.)Remove o suporte para passagem de argumentos posicionais adicionais para
PurePath.relative_to()
eis_relative_to()
. Em versões anteriores, tais argumentos eram unidos a other. (Contribuição de Barney Gale em gh-78707.)
pkgutil¶
Remove as funções
get_loader()
efind_loader()
, que foram descontinuadas desde o Python 3.12. (Contribuição de Bénédikt Tran em gh-97850.)
pty¶
Remove as funções
master_open()
eslave_open()
, que foram descontinuadas desde o Python 3.12. Em vez disso, usepty.openpty()
. (Contribuição de Nikita Sobolev em gh-118824.)
sqlite3¶
Remove
version
eversion_info
do módulosqlite3
; usesqlite_version
esqlite_version_info
para o número da versão real da biblioteca SQLite em tempo de execução. (Contribuição de Hugo van Kemenade em gh-118924.)Usar uma sequência de parâmetros com espaços reservados nomeados agora levanta uma
ProgrammingError
, que estava descontinuado desde o Python 3.12. (Contribuição de Erlend E. Aasland em gh-118928 e gh-101693.)
urllib¶
Remove a classe
Quoter
deurllib.parse
, que está descontinuada desde o Python 3.11. (Contribuição de Nikita Sobolev em gh-118827.)Remove as classes
URLopener
eFancyURLopener
deurllib.request
, que foram descontinuadas desde o Python 3.3.myopener.open()
pode ser substituído porurlopen()
.myopener.retrieve()
pode ser substituído porurlretrieve()
. Personalizações nas classes de abertura podem ser feitas passando manipuladores personalizados parabuild_opener()
. (Contribuição de Barney Gale em gh-84850.)
Descontinuados¶
-
A passagem do argumento nomeado não documentado prefix_chars para
add_argument_group()
agora está descontinuado. (Contribuição de Savannah Ostrowski em gh-125563.)O conversor de tipo
argparse.FileType
foi descontinuado. Qualquer coisa com gerenciamento de recursos deve ser feita posteriormente, após a análise dos argumentos. (Contribuição de Serhiy Storchaka em gh-58032.)
-
asyncio.iscoroutinefunction()
foi descontinuado e será removido no Python 3.16, useinspect.iscoroutinefunction()
em vez disso. (Contribuição de Jiahao Li e Kumar Aditya em gh-122875.)O sistema de políticas
asyncio
está descontinuado e será removido no Python 3.16. Em particular, as seguintes classes e funções estão descontinuadas:Os usuários devem usar
asyncio.run()
ouasyncio.Runner
com loop_factory para usar a implementação de loop de eventos desejada.por exemplo, para usar
asyncio.SelectorEventLoop
no Windows:import asyncio async def main(): ... asyncio.run(main(), loop_factory=asyncio.SelectorEventLoop)
(Contribuição de Kumar Aditya em gh-127949.)
builtins
: Passar um número complexo como argumento real ou imag no construtorcomplex()
agora está descontinuado; deve ser passado apenas como um único argumento posicional. (Contribuição de Serhiy Storchaka em gh-109218.)codecs
:codecs.open()
está descontinuada. Em vez disso, useopen()
. (Contribuição de Inada Naoki em gh-133036.)-
Em plataformas não Windows, a configuração de
Structure._pack_
para usar um layout de memória padrão compatível com MSVC foi descontinuada, em favor da configuração deStructure._layout_
para'ms'
. (Contribuição de Petr Viktorin em gh-131747.)A chamada de
ctypes.POINTER()
em uma string está descontinuada. Use Tipos Incompletos para estruturas autorreferenciais. Além disso, octypes._pointer_type_cache
interno está descontinuado. Consultectypes.POINTER()
para obter detalhes de implementação atualizados. (Contribuição de Sergey Myrianov em gh-100926.)
functools
: Chamar a implementação Python defunctools.reduce()
com function ou sequence como argumentos nomeados agora está descontinuado. (Contribuição de Kirill Podoprigora em gh-121676.)logging
: O suporte para manipuladores de registro personalizados com o argumento strm foi descontinuado e está programado para ser removido no Python 3.16. Em vez disso, defina manipuladores com o argumento stream. (Contribuição de Mariusz Felisiak em gh-115032.)mimetypes
:Extensões válidas começam com um ‘.’ ou estão vazias paramimetypes.MimeTypes.add_type()
. Extensões sem ponto estão descontinuadas e levantarão uma exceçãoValueError
no Python 3.16. (Contribuição de Hugo van Kemenade em gh-75223.)nturl2path
: Este módulo está descontinuado. Em vez disso, chameurllib.request.url2pathname()
epathname2url()
. (Contribuição de Barney Gale em gh-125866.)os
: Descontinua suavemente funçõesos.popen()
eos.spawn*
. Elas não devem mais ser usadas para escrever código novo. O módulosubprocess
é recomendado em seu lugar. (Contribuição de Victor Stinner em gh-120743.)pathlib
:pathlib.PurePath.as_uri()
está descontinuado e será removido no Python 3.19. Em vez disso, usepathlib.Path.as_uri()
. (Contribuição de Barney Gale em gh-123599.)pdb
: O atributo não documentadopdb.Pdb.curframe_locals
agora é uma propriedade somente leitura descontinuada. O acesso dinâmico de baixa sobrecarga aos locais de quadro, adicionado no Python 3.13 pela PEP 667, significa que a referência ao cache de locais de quadro, armazenada anteriormente neste atributo, não é mais necessária. Depuradores derivados devem acessarpdb.Pdb.curframe.f_locals
diretamente no Python 3.13 e versões posteriores. (Contribuição de Tian Gao em gh-124369 e gh-125951.)symtable
: Descontinuasymtable.Class.get_methods()
por falta de interesse. (Contribuição de Bénédikt Tran em gh-119698.)tkinter
: Os métodostkinter.Variable
trace_variable()
,trace_vdelete()
etrace_vinfo()
estão descontinuados. Em vez disso, usetrace_add()
,trace_remove()
etrace_info()
. (Contribuição de Serhiy Storchaka em gh-120220.)urllib.parse
: Aceitar objetos com valores falsos (como0
e[]
), exceto strings vazias, objetos bytes ou similares eNone
nas funçõesurllib.parse
parse_qsl()
eparse_qs()
, agora está descontinuado. (Contribuição de Serhiy Storchaka em gh-116897.)
Remoção pendente no Python 3.15¶
O sistema de importação:
A definição de
__cached__
em um módulo enquanto falha na definição de__spec__.cached
está descontinuado. No Python 3.15,__cached__
deixará de ser definido ou levado em consideração pelo sistema de importação ou pela biblioteca padrão. (gh-97879)A definição de
__package__
em um módulo enquanto falha na definição de__spec__.parent
está descontinuado. No Python 3.15,__package__
deixará de ser definido ou levado em consideração pelo sistema de importação ou pela biblioteca padrão. (gh-97879)
-
A função não documentada
ctypes.SetPointerType()
foi descontinuada desde o Python 3.13.
-
The obsolete and rarely used
CGIHTTPRequestHandler
has been deprecated since Python 3.13. No direct replacement exists. Anything is better than CGI to interface a web server with a request handler.O sinalizador
--cgi
para a interface de linha de comando python -m http.server foi descontinuado desde o Python 3.13.
-
Método
load_module()
: useexec_module()
.
-
A função
getdefaultlocale()
foi descontinuada desde o Python 3.11. Sua remoção foi planejada originalmente para o Python 3.13 (gh-90817), mas foi adiada para o Python 3.15. Em vez disso, usegetlocale()
,setlocale()
egetencoding()
. (Contribuição de Hugo van Kemenade em gh-111187.)
-
.PurePath.is_reserved()
has been deprecated since Python 3.13. Useos.path.isreserved()
to detect reserved paths on Windows.
-
platform.java_ver()
has been deprecated since Python 3.13. This function is only useful for Jython support, has a confusing API, and is largely untested.
-
O argumento check_home de
sysconfig.is_python_build()
foi descontinuado desde o Python 3.12.
-
RLock()
não aceitará argumentos no Python 3.15. A passagem quaisquer argumentos foi descontinuada desde o Python 3.14, pois a versão Python não permite nenhum argumento, mas a versão C permite qualquer número de argumentos posicionais ou nomeados, ignorando todos os argumentos.
-
types.CodeType
: o acesso aco_lnotab
foi descontinuado na PEP 626 desde 3.10 e foi planejado para ser removido em 3.12, mas só recebeu umaDeprecationWarning
adequada em 3.12. Pode ser removido em 3.15. (Contribuição de Nikita Sobolev em gh-101866.)
-
A não-documentada sintaxe de argumento nomeado para criar classes
NamedTuple
(por exemplo,Point = NamedTuple("Point", x=int, y=int)
) foi descontinuada desde o Python 3.13. Em vez disso, use as sintaxes baseada em classe ou funcional.Ao usar a sintaxe funcional de
TypedDict
s, não passar um valor para o parâmetro fields (TD = TypedDict("TD")
) ou passarNone
(TD = TypedDict("TD", None)
) foi está descontinuado desde o Python 3.13. Useclass TD(TypedDict): pass
ouTD = TypedDict("TD", {})
para criar uma classe TypedDict com nenhum campo.A função decoradora
typing.no_type_check_decorator()
foi descontinuada desde o Python 3.13. Após oito anos no módulotyping
, ela ainda não foi suportada por nenhum verificador de tipo importante.
Módulos
sre_compile
,sre_constants
esre_parse
.wave
:The
getmark()
,setmark()
andgetmarkers()
methods of theWave_read
andWave_write
classes have been deprecated since Python 3.13.
-
zipimport.zipimporter.load_module()
has been deprecated since Python 3.10. Useexec_module()
instead. (gh-125746.)
Remoção pendente no Python 3.16¶
O sistema de importação:
A definição de
__loader__
em um módulo enquanto falha na definição de__spec__.loader
está descontinuado. No Python 3.16,__loader__
deixará de ser definido ou levado em consideração pelo sistema de importação ou pela biblioteca padrão.
-
O código de formato
'u'
(wchar_t
) foi descontinuado na documentação desde o Python 3.3 e do ambiente de execução desde o Python 3.13. Em vez disso, use o código de formato'w'
(Py_UCS4
) para caracteres Unicode.
-
asyncio.iscoroutinefunction()
foi descontinuado e será removido no Python 3.16, useinspect.iscoroutinefunction()
em vez disso. (Contribuição de Jiahao Li e Kumar Aditya em gh-122875.)O sistema de políticas
asyncio
está descontinuado e será removido no Python 3.16. Em particular, as seguintes classes e funções estão descontinuadas:Os usuários devem usar
asyncio.run()
ouasyncio.Runner
com loop_factory para usar a implementação de loop de eventos desejada.por exemplo, para usar
asyncio.SelectorEventLoop
no Windows:import asyncio async def main(): ... asyncio.run(main(), loop_factory=asyncio.SelectorEventLoop)
(Contribuição de Kumar Aditya em gh-127949.)
-
A inversão bit a bit em tipos booleanos,
~True
ou~False
foi descontinuada desde o Python 3.12, pois produz resultados surpreendentes e não intuitivos (-2
e-1
). Em vez disso, usenot x
para a negação lógica de um booleano. No caso raro de você precisar da inversão bit a bit do inteiro subjacente, converta paraint
explicitamente (~int(x)
).
-
A chamada da implementação Python de
functools.reduce()
com function ou sequence como argumentos nomeados foi descontinuada desde o Python 3.14.
-
O suporte para manipuladores de registro personalizados com o argumento strm foi descontinuado e está programado para ser removido no Python 3.16. Em vez disso, defina manipuladores com o argumento stream. (Contribuição de Mariusz Felisiak em gh-115032.)
-
Extensões válidas começam com um ‘.’ ou estão vazias para
mimetypes.MimeTypes.add_type()
. Extensões sem ponto estão descontinuadas e levantarão uma exceçãoValueError
no Python 3.16. (Contribuição de Hugo van Kemenade em gh-75223.)
-
A exceção
ExecError
foi descontinuada desde o Python 3.14. Ela não foi usada por nenhuma função emshutil
desde o Python 3.4, e agora é um alias deRuntimeError
.
-
O método
Class.get_methods
foi descontinuado desde o Python 3.14.
sys
:A função
_enablelegacywindowsfsencoding()
foi descontinuada desde o Python 3.13. Em vez disso, use a variável de ambientePYTHONLEGACYWINDOWSFSENCODING
.
-
A função
sysconfig.expand_makefile_vars()
está descontinuada desde o Python 3.14. Em vez disso, use o argumentovars
desysconfig.get_paths()
.
-
O atributo não documentado e não utilizado
TarFile.tarfile
foi descontinuado desde o Python 3.13.
Remoção pendente no Python 3.17¶
-
collections.abc.ByteString
está agendado para remoção no Python 3.17.Use
isinstance(obj, collections.abc.Buffer)
para testar seobj
implementa o protocolo de buffer em tempo de execução. Para uso em anotações de tipo, useBuffer
ou uma união que especifique explicitamente os tipos suportados pelo seu código (por exemplo,bytes | bytearray | memoryview
).ByteString
foi originalmente concebido para ser uma classe abstrata que serviria como um supertipo debytes
ebytearray
. No entanto, como o ABC nunca teve métodos, saber que um objeto era uma instância deByteString
nunca lhe dizia nada de útil sobre o objeto. Outros tipos comuns de buffer, comomemoryview
, também nunca foram entendidos como subtipos deByteString
(seja em tempo de execução ou por verificadores de tipo estáticos).Veja PEP 688 para mais detalhes. (Contribuição de Shantanu Jain em gh-91896.)
-
Antes do Python 3.14, as uniões antigas eram implementadas usando a classe privada
typing._UnionGenericAlias
. Essa classe não é mais necessária para a implementação, mas foi mantida para compatibilidade com versões anteriores, com remoção prevista para o Python 3.17. Os usuários devem usar auxiliares de introspecção documentados, comotyping.get_origin()
etyping.get_args()
, em vez de depender de detalhes de implementação privada.typing.ByteString
, obsoleto desde o Python 3.9, está programado para ser removido no Python 3.17.Use
isinstance(obj, collections.abc.Buffer)
para testar seobj
implementa o protocolo de buffer em tempo de execução. Para uso em anotações de tipo, useBuffer
ou uma união que especifique explicitamente os tipos suportados pelo seu código (por exemplo,bytes | bytearray | memoryview
).ByteString
foi originalmente concebido para ser uma classe abstrata que serviria como um supertipo debytes
ebytearray
. No entanto, como o ABC nunca teve métodos, saber que um objeto era uma instância deByteString
nunca lhe dizia nada de útil sobre o objeto. Outros tipos comuns de buffer, comomemoryview
, também nunca foram entendidos como subtipos deByteString
(seja em tempo de execução ou por verificadores de tipo estáticos).Veja PEP 688 para mais detalhes. (Contribuição de Shantanu Jain em gh-91896.)
Remoção pendente no Python 3.19¶
-
In hash function constructors such as
new()
or the direct hash-named constructors such asmd5()
andsha256()
, their optional initial data parameter could also be passed a keyword argument nameddata=
orstring=
in varioushashlib
implementations.Support for the
string
keyword argument name is now deprecated and slated for removal in Python 3.19.Before Python 3.13, the
string
keyword parameter was not correctly supported depending on the backend implementation of hash functions. Prefer passing the initial data as a positional argument for maximum backwards compatibility.
Remoção pendente em versões futuras¶
As APIs a seguir serão removidas no futuro, embora atualmente não haja uma data agendada para sua remoção.
-
O aninhamento de grupos de argumentos e o aninhamento de grupos mutuamente exclusivos estão descontinuado.
A passagem do argumento nomeado não documentado prefix_chars para
add_argument_group()
agora está descontinuado.O conversor de tipo
argparse.FileType
está descontinuado.
-
bool(NotImplemented)
.Geradores: a assinatura
throw(type, exc, tb)
eathrow(type, exc, tb)
está descontinuada: usethrow(exc)
eathrow(exc)
, a assinatura do argumento único.Atualmente Python aceita literais numéricos imediatamente seguidos por palavras reservadas como, por exemplo,
0in x
,1or x
,0if 1else 2
. Ele permite expressões confusas e ambíguas como[0x1for x in y]
(que pode ser interpretada como[0x1 for x in y]
ou[0x1f or x in y]
). Um aviso de sintaxe é levantado se o literal numérico for imediatamente seguido por uma das palavras reservadasand
,else
,for
,if
,in
,is
eor
. Em uma versão futura, será alterado para um erro de sintaxe. (gh-87999)Suporte para métodos
__index__()
e__int__()
retornando tipo não-int: esses métodos serão necessários para retornar uma instância de uma subclasse estrita deint
.Suporte para o método
__float__()
retornando uma subclasse estrita defloat
: esses métodos serão necessários para retornar uma instância defloat
.Suporte para o método
__complex__()
retornando uma subclasse estrita decomplex
: esses métodos serão necessários para retornar uma instância decomplex
.Delegação do método
int()
para o__trunc__()
.Passar um número complexo como argumento real ou imag no construtor
complex()
agora está descontinuado; deve ser passado apenas como um único argumento posicional. (Contribuição de Serhiy Storchaka em gh-109218.)
calendar
: as constantescalendar.January
ecalendar.February
foram descontinuadas e substituídas porcalendar.JANUARY
ecalendar.FEBRUARY
. (Contribuição de Prince Roshan em gh-103636.)codecs
: useopen()
em vez decodecs.open()
. (gh-133038)codeobject.co_lnotab
: use o métodocodeobject.co_lines()
.-
utcnow()
: usedatetime.datetime.now(tz=datetime.UTC)
.utcfromtimestamp()
: usedatetime.datetime.fromtimestamp(timestamp, tz=datetime.UTC)
.
gettext
: o valor de plural deve ser um número inteiro.-
O parâmetro debug_override de
cache_from_source()
foi descontinuado: use o parâmetro optimization.
-
Interface de tupla
EntryPoints
.None
implícito nos valores de retorno.
logging
: o métodowarn()
foi descontinuado desde o Python 3.3, usewarning()
.mailbox
: o uso da entrada StringIO e do modo de texto foi descontinuado; em vez disso, use BytesIO e o modo binário.os
: chameos.register_at_fork()
em processo multithread.pydoc.ErrorDuringImport
: um valor de tupla para o parâmetro exc_info foi descontinuado, use uma instância de exceção.re
: regras mais rigorosas agora são aplicadas para referências numéricas de grupos e nomes de grupos em expressões regulares. Apenas a sequência de dígitos ASCII agora é aceita como referência numérica. O nome do grupo em padrões de bytes e strings de substituição agora pode conter apenas letras e dígitos ASCII e sublinhado. (Contribuição de Serhiy Storchaka em gh-91760.)shutil
: o parâmetro onerror dermtree()
foi descontinuado no Python 3.12; use o parâmetro onexc.Protocolos e opções de
ssl
ssl.SSLContext
sem argumento de protocolo foi descontinuado.ssl.SSLContext
:set_npn_protocols()
eselected_npn_protocol()
foram descontinuados, use ALPN.Opções de
ssl.OP_NO_SSL*
Opções de
ssl.OP_NO_TLS*
ssl.PROTOCOL_SSLv3
ssl.PROTOCOL_TLS
ssl.PROTOCOL_TLSv1
ssl.PROTOCOL_TLSv1_1
ssl.PROTOCOL_TLSv1_2
ssl.TLSVersion.SSLv3
ssl.TLSVersion.TLSv1
ssl.TLSVersion.TLSv1_1
Métodos de
threading
:threading.Condition.notifyAll()
: usenotify_all()
.threading.Event.isSet()
: useis_set()
.threading.Thread.isDaemon()
,threading.Thread.setDaemon()
: use o atributothreading.Thread.daemon
.threading.Thread.getName()
,threading.Thread.setName()
: use o atributothreading.Thread.name
.threading.currentThread()
: usethreading.current_thread()
.threading.activeCount()
: usethreading.active_count()
.
A classe interna
typing._UnionGenericAlias
não é mais usada para implementartyping.Union
. Para preservar a compatibilidade com usuários que utilizam esta classe privada, uma correção de compatibilidade será fornecida pelo menos até a versão 3.17 do Python. (Contribuição de Jelle Zijlstra em gh-105499.)unittest.IsolatedAsyncioTestCase
: foi descontinuado retornar um valor que não sejaNone
de um caso de teste.Funções descontinuadas de
urllib.parse
: useurlparse()
splitattr()
splithost()
splitnport()
splitpasswd()
splitport()
splitquery()
splittag()
splittype()
splituser()
splitvalue()
to_bytes()
wsgiref
:SimpleHandler.stdout.write()
não deve fazer gravações parciais.xml.etree.ElementTree
: testar o valor verdade de umElement
está descontinuado. Em um lançamento futuro isso sempre retornaráTrue
. Em vez disso, prefira os testes explícitoslen(elem)
ouelem is not None
.sys._clear_type_cache()
está descontinuada: usesys._clear_internal_caches()
.
Alterações de bytecode do CPython¶
Alterações na API C¶
Novos recursos na API C¶
Adiciona
Py_PACK_VERSION()
ePy_PACK_FULL_VERSION()
, duas novas macros para empacotamento de bits de números de versão do Python. Isso é útil para comparações comPy_Version
ouPY_VERSION_HEX
. (Contribuição de Petr Viktorin em gh-128629.)Adiciona a função
PyBytes_Join(sep, iterable)
, semelhante asep.join(iterable)
em Python. (Contribuição de Victor Stinner em gh-121645.)Adiciona funções para manipular a configuração do interpretador Python de tempo de execução atual (PEP 741: API C de Configuração do Python):
(Contribuição de Victor Stinner em gh-107954.)
Adiciona funções para configurar a inicialização do Python (PEP 741: API C de Configuração do Python):
(Contribuição de Victor Stinner em gh-107954.)
Adiciona a função
Py_fopen()
para abrir um arquivo. Isso funciona de forma semelhante à função padrão do Cfopen()
, aceitando um objeto Python como parâmetro path e definindo uma exceção em caso de erro. A nova função correspondentePy_fclose()
deve ser usada para fechar um arquivo. (Contribuição de Victor Stinner em gh-127350.)Adiciona
Py_HashBuffer()
para calcular e retornar o valor de hash de um buffer. (Contribuição de Antoine Pitrou e Victor Stinner em gh-122854.)Adiciona as funções auxiliares
PyImport_ImportModuleAttr()
ePyImport_ImportModuleAttrString()
para importar um módulo e obter um atributo do módulo. (Contribuição de Victor Stinner em gh-128911.)Adiciona
PyIter_NextItem()
para substituirPyIter_Next()
, que tem um valor de retorno ambíguo. (Contribuição de Irit Katriel e Erlend Aasland em gh-105201.)Adiciona a função
PyLong_GetSign()
para obter o sinal de objetosint
. (Contribuição de Sergey B Kirpichev em gh-116560.)Adiciona
PyLong_IsPositive()
,PyLong_IsNegative()
ePyLong_IsZero()
para verificar sePyLongObject
é positivo, negativo ou zero, respectivamente. (Contribuição de James Roy e Sergey B Kirpichev em gh-126061.)Add new functions to convert C
<stdint.h>
numbers to/from Pythonint
objects:(Contribuição de Victor Stinner em gh-120389.)
Adiciona uma nova API de importação e exportação para objetos Python
int
(PEP 757):(Contribuição de Sergey B Kirpichev e Victor Stinner em gh-102471.)
Add
PyMonitoring_FireBranchLeftEvent()
andPyMonitoring_FireBranchRightEvent()
for generatingBRANCH_LEFT
andBRANCH_RIGHT
events, respectively. (Contributed by Mark Shannon in gh-122548.)Adiciona a função
PyType_Freeze()
para tornar um tipo imutável. (Contribuição de Victor Stinner em gh-121654.)Add
PyType_GetBaseByToken()
andPy_tp_token
slot for easier superclass identification, which attempts to resolve the type checking issue mentioned in PEP 630. (Contributed in gh-124153.)Add a new
PyUnicode_Equal()
function to test if two strings are equal. The function is also added to the Limited C API. (Contributed by Victor Stinner in gh-124502.)Add a new
PyUnicodeWriter
API to create a Pythonstr
object, with the following functions:(Contribuição de Victor Stinner em gh-119182.)
Os formatos
k
eK
emPyArg_ParseTuple()
e funções similares agora usam__index__()
se disponível, assim como todos os outros formatos inteiros. (Contribuição de Serhiy Storchaka em gh-112068.)Add support for a new
p
format unit inPy_BuildValue()
that produces a Pythonbool
object from a C integer. (Contributed by Pablo Galindo in bpo-45325.)Add
PyUnstable_IsImmortal()
for determining if an object is immortal, for debugging purposes. (Contributed by Peter Bierma in gh-128509.)Adiciona
PyUnstable_Object_EnableDeferredRefcount()
para habilitar a contagem de referências adiada, conforme descrito em PEP 703.Adiciona
PyUnstable_Object_IsUniquelyReferenced()
como substituto paraPy_REFCNT(op) == 1
em construções com threads livres. (Contribuição de Peter Bierma em gh-133140.)Add
PyUnstable_Object_IsUniqueReferencedTemporary()
to determine if an object is a unique temporary object on the interpreter’s operand stack. This can be used in some cases as a replacement for checking ifPy_REFCNT()
is1
for Python objects passed as arguments to C API functions. (Contributed by Sam Gross in gh-133164.)
Mudanças na API C limitada¶
In the limited C API version 3.14 and newer,
Py_TYPE()
andPy_REFCNT()
are now implemented as an opaque function call to hide implementation details. (Contributed by Victor Stinner in gh-120600 and gh-124127.)Remove the
PySequence_Fast_GET_SIZE
,PySequence_Fast_GET_ITEM
, andPySequence_Fast_ITEMS
macros from the limited C API, since they have always been broken in the limited C API. (Contributed by Victor Stinner in gh-91417.)
APIs C removidas¶
Creating
immutable types
with mutable bases was deprecated in Python 3.12, and now raises aTypeError
. (Contributed by Nikita Sobolev in gh-119775.)Remove
PyDictObject.ma_version_tag
member, which was deprecated in Python 3.12. Use thePyDict_AddWatcher()
API instead. (Contributed by Sam Gross in gh-124296.)Remova a função privada
_Py_InitializeMain()
. Era uma API provisória adicionada ao Python 3.8 pela PEP 587. (Contribuição de Victor Stinner em gh-129033.)Remove the undocumented APIs
Py_C_RECURSION_LIMIT
andPyThreadState.c_recursion_remaining
. These were added in 3.13 and have been removed without deprecation. UsePy_EnterRecursiveCall()
to guard against runaway recursion in C code. (Removed by Petr Viktorin in gh-133079, see also gh-130396.)
APIs C descontinuadas¶
The
Py_HUGE_VAL
macro is now soft deprecated. UsePy_INFINITY
instead. (Contributed by Sergey B Kirpichev in gh-120026.)The
Py_IS_NAN
,Py_IS_INFINITY
, andPy_IS_FINITE
macros are now soft deprecated. Useisnan
,isinf
andisfinite
instead, available frommath.h
since C99. (Contributed by Sergey B Kirpichev in gh-119613.)Non-tuple sequences are now deprecated as argument for the
(items)
format unit inPyArg_ParseTuple()
and other argument parsing functions if items contains format units which store a borrowed buffer or a borrowed reference. (Contributed by Serhiy Storchaka in gh-50333.)The
_PyMonitoring_FireBranchEvent
function is now deprecated and should be replaced with calls toPyMonitoring_FireBranchLeftEvent()
andPyMonitoring_FireBranchRightEvent()
.The previously undocumented function
PySequence_In()
is now soft deprecated. UsePySequence_Contains()
instead. (Contributed by Yuki Kobayashi in gh-127896.)
Remoção pendente no Python 3.15¶
The
PyImport_ImportModuleNoBlock()
: UsePyImport_ImportModule()
instead.PyWeakref_GetObject()
andPyWeakref_GET_OBJECT()
: UsePyWeakref_GetRef()
instead. The pythoncapi-compat project can be used to getPyWeakref_GetRef()
on Python 3.12 and older.O tipo
Py_UNICODE
e a macroPy_UNICODE_WIDE
: usewchar_t
.PyUnicode_AsDecodedObject()
: usePyCodec_Decode()
.PyUnicode_AsDecodedUnicode()
: UsePyCodec_Decode()
; Note que alguns codecs (por exemplo, “base64”) podem retornar um tipo diferente destr
, tal comobytes
.PyUnicode_AsEncodedObject()
: usePyCodec_Encode()
.PyUnicode_AsEncodedUnicode()
: UsePyCodec_Encode()
; Note que alguns codecs (por exemplo, “base64”) podem retornar um tipo diferente debytes
, tal comstr
.Funções de inicialização do Python, descontinuadas no Python 3.9:
Py_GetPath()
: UsePyConfig_Get("module_search_paths")
(sys.path
) instead.Py_GetPrefix()
: UsePyConfig_Get("base_prefix")
(sys.base_prefix
) instead. UsePyConfig_Get("prefix")
(sys.prefix
) if virtual environments need to be handled.Py_GetExecPrefix()
: UsePyConfig_Get("base_exec_prefix")
(sys.base_exec_prefix
) instead. UsePyConfig_Get("exec_prefix")
(sys.exec_prefix
) if virtual environments need to be handled.Py_GetProgramFullPath()
: UsePyConfig_Get("executable")
(sys.executable
) instead.Py_GetProgramName()
: UsePyConfig_Get("executable")
(sys.executable
) instead.Py_GetPythonHome()
: UsePyConfig_Get("home")
or thePYTHONHOME
environment variable instead.
O projeto pythoncapi-compat pode ser usado para obter
PyConfig_Get()
no Python 3.13 e versões anteriores.Funções para configurar a inicialização do Python, descontinuadas no Python 3.11:
PySys_SetArgvEx()
: definaPyConfig.argv
.PySys_SetArgv()
: definaPyConfig.argv
.Py_SetProgramName()
: definaPyConfig.program_name
.Py_SetPythonHome()
: definaPyConfig.home
.PySys_ResetWarnOptions()
: Clearsys.warnoptions
andwarnings.filters
instead.
Em vez disso, a API
Py_InitializeFromConfig()
deve ser usada comPyConfig
.Variáveis de configuração globais
Py_DebugFlag
: UsePyConfig.parser_debug
ouPyConfig_Get("parser_debug")
.Py_VerboseFlag
: UsePyConfig.verbose
ouPyConfig_Get("verbose")
.Py_InteractiveFlag
: UsePyConfig.interactive
ouPyConfig_Get("interactive")
.Py_InspectFlag
: UsePyConfig.inspect
ouPyConfig_Get("inspect")
.Py_OptimizeFlag
: UsePyConfig.optimization_level
ouPyConfig_Get("optimization_level")
.Py_NoSiteFlag
: UsePyConfig.site_import
ouPyConfig_Get("site_import")
.Py_BytesWarningFlag
: UsePyConfig.bytes_warning
ouPyConfig_Get("bytes_warning")
.Py_FrozenFlag
: UsePyConfig.pathconfig_warnings
ouPyConfig_Get("pathconfig_warnings")
.Py_IgnoreEnvironmentFlag
: UsePyConfig.use_environment
ouPyConfig_Get("use_environment")
.Py_DontWriteBytecodeFlag
: UsePyConfig.write_bytecode
ouPyConfig_Get("write_bytecode")
.Py_NoUserSiteDirectory
: UsePyConfig.user_site_directory
ouPyConfig_Get("user_site_directory")
.Py_UnbufferedStdioFlag
: UsePyConfig.buffered_stdio
ouPyConfig_Get("buffered_stdio")
.Py_HashRandomizationFlag
: UsePyConfig.use_hash_seed
ePyConfig.hash_seed
ouPyConfig_Get("hash_seed")
.Py_IsolatedFlag
: UsePyConfig.isolated
ouPyConfig_Get("isolated")
.Py_LegacyWindowsFSEncodingFlag
: UsePyPreConfig.legacy_windows_fs_encoding
ouPyConfig_Get("legacy_windows_fs_encoding")
.Py_LegacyWindowsStdioFlag
: UsePyConfig.legacy_windows_stdio
ouPyConfig_Get("legacy_windows_stdio")
.Py_FileSystemDefaultEncoding
,Py_HasFileSystemDefaultEncoding
: UsePyConfig.filesystem_encoding
ouPyConfig_Get("filesystem_encoding")
.Py_FileSystemDefaultEncodeErrors
: UsePyConfig.filesystem_errors
ouPyConfig_Get("filesystem_errors")
.Py_UTF8Mode
: UsePyPreConfig.utf8_mode
ouPyConfig_Get("utf8_mode")
. (vejaPy_PreInitialize()
)
A API
Py_InitializeFromConfig()
deve ser usada comPyConfig
para definir essas opções. OuPyConfig_Get()
pode ser usado para obter essas opções em tempo de execução.
Remoção pendente no Python 3.16¶
A cópia empacotada do
libmpdec
.
Remoção pendente no Python 3.18¶
As seguintes funções privadas estão descontinuado e planejadas para remoção no Python 3.18:
_PyBytes_Join()
: usePyBytes_Join()
._PyDict_GetItemStringWithError()
: usePyDict_GetItemStringRef()
._PyDict_Pop()
: usePyDict_Pop()
._PyLong_Sign()
: usePyLong_GetSign()
._PyLong_FromDigits()
e_PyLong_New()
: usePyLongWriter_Create()
._PyThreadState_UncheckedGet()
: usePyThreadState_GetUnchecked()
._PyUnicode_AsString()
: usePyUnicode_AsUTF8()
._PyUnicodeWriter_Init()
: substitua_PyUnicodeWriter_Init(&writer)
porwriter = PyUnicodeWriter_Create(0)
._PyUnicodeWriter_Finish()
: substitua_PyUnicodeWriter_Finish(&writer)
porPyUnicodeWriter_Finish(writer)
._PyUnicodeWriter_Dealloc()
: substitua_PyUnicodeWriter_Dealloc(&writer)
porPyUnicodeWriter_Discard(writer)
._PyUnicodeWriter_WriteChar()
: substituta_PyUnicodeWriter_WriteChar(&writer, ch)
porPyUnicodeWriter_WriteChar(writer, ch)
._PyUnicodeWriter_WriteStr()
: substitua_PyUnicodeWriter_WriteStr(&writer, str)
porPyUnicodeWriter_WriteStr(writer, str)
._PyUnicodeWriter_WriteSubstring()
: substitua_PyUnicodeWriter_WriteSubstring(&writer, str, start, end)
porPyUnicodeWriter_WriteSubstring(writer, str, start, end)
._PyUnicodeWriter_WriteASCIIString()
: substitua_PyUnicodeWriter_WriteASCIIString(&writer, str)
porPyUnicodeWriter_WriteASCII(writer, str)
._PyUnicodeWriter_WriteLatin1String()
: substitua_PyUnicodeWriter_WriteLatin1String(&writer, str)
porPyUnicodeWriter_WriteUTF8(writer, str)
._PyUnicodeWriter_Prepare()
: (sem substituto)._PyUnicodeWriter_PrepareKind()
: (sem substituto)._Py_HashPointer()
: usePy_HashPointer()
._Py_fopen_obj()
: usePy_fopen()
.
O projeto pythoncapi-compat pode ser usado para obter essas novas funções públicas no Python 3.13 e versões anteriores. (Contribuição de Victor Stinner em gh-128863.)
Remoção pendente em versões futuras¶
As APIs a seguir foram descontinuadas e serão removidas, embora atualmente não haja uma data agendada para sua remoção.
Py_TPFLAGS_HAVE_FINALIZE
: desnecessária desde o Python 3.8.PySlice_GetIndicesEx()
: usePySlice_Unpack()
ePySlice_AdjustIndices()
.PyUnicode_READY()
: desnecessário desde o Python 3.12PyErr_Display()
: usePyErr_DisplayException()
._PyErr_ChainExceptions()
: use_PyErr_ChainExceptions1()
.O membro
PyBytesObject.ob_shash
: chamePyObject_Hash()
.API do Thread Local Storage (TLS):
PyThread_ReInitTLS()
: desnecessário desde o Python 3.7.
Alterações na construção¶
O GNU Autoconf 2.72 agora é necessário para gerar o
configure
. (Contribuição de Erlend Aasland em gh-115765.)wasm32-unknown-emscripten
agora é uma plataforma de nível 3 segundo a PEP 11. (Contribuição de R. Hood Chatham em gh-127146, gh-127683 e gh-136931.)A vinculação baseada em
#pragma
compython3*.lib
agora pode ser desativada com Py_NO_LINK_LIB. (Contribuição de Jean-Christophe Fillion-Robin em gh-82909.)O CPython agora habilita um conjunto de opções de compilador recomendadas por padrão para maior segurança. Use as opções
--disable-safety
econfigure
para desabilitá-las, ou a opção--enable-slower-safety
para um conjunto maior de opções de compilador, embora com um custo de desempenho.A macro
WITH_FREELISTS
e a opção--without-freelists
configure
foram removidas.A nova opção
configure
--with-tail-call-interp
pode ser usada para habilitar o interpretador experimental de chamada de cauda. Consulte Um novo tipo de interpretador para mais detalhes.Para desabilitar o novo suporte à depuração remota, use as opções
--without-remote-debug
econfigure
. Isso pode ser útil por motivos de segurança.
build-details.json
¶
As instalações do Python agora contêm um novo arquivo, build-details.json
. Este é um documento JSON estático contendo detalhes da construção do CPython, permitindo introspecção sem a necessidade de executar código. Isso é útil para casos de uso como inicializadores do Python, compilação cruzada e assim por diante.
build-details.json
deve ser instalado no diretório da biblioteca padrão independente de plataforma. Isso corresponde ao caminho de instalação ‘stdlib’ sysconfig
, que pode ser encontrado executando sysconfig.get_path('stdlib')
.
Ver também
PEP 739 – build-details.json
1.0 – um arquivo de descrição estática para detalhes de construção do Python
Descontinuação de assinaturas PGP¶
Assinaturas PGP (Pretty Good Privacy) não serão fornecidas para versões do Python 3.14 ou versões futuras. Para verificar artefatos do CPython, os usuários devem usar materiais de verificação do Sigstore. As versões são assinadas usando o Sigstore desde o Python 3.11.
Essa mudança no processo de lançamento foi especificada em PEP 761.
Portando para o Python 3.14¶
Esta seção lista as alterações descritas anteriormente e outras correções que podem exigir alterações no seu código.
Alterações na API Python¶
functools.partial
agora é um descritor de método. Envolva-o emstaticmethod()
se quiser preservar o comportamento antigo. (Contribuição de Serhiy Storchaka e Dominykas Grigonis em gh-121027.)O coletor de lixo agora é incremental, o que significa que o comportamento de
gc.collect()
muda ligeiramente:gc.collect(1)
: Executa um incremento da coleta de lixo, em vez de coletar a geração 1.Outras chamadas para
gc.collect()
não foram alteradas.
A função
locale.nl_langinfo()
agora define temporariamente a localidadeLC_CTYPE
em alguns casos. Esta alteração temporária afeta outras threads. (Contribuição de Serhiy Storchaka em gh-69998.)types.UnionType
agora é um apelido paratyping.Union
, causando alterações em alguns comportamentos. Veja acima para mais detalhes. (Contribuição de Jelle Zijlstra em gh-105499.)O comportamento das anotações em tempo de execução mudou de várias maneiras; veja acima para mais detalhes. Embora a maioria dos códigos que interagem com anotações deva continuar funcionando, alguns detalhes não documentados podem se comportar de forma diferente.
Alterações na API C¶
Py_Finalize()
agora exclui todas as strings internalizadas. Isso é incompatível com versões anteriores de qualquer extensão C que retenha uma string internada após uma chamada paraPy_Finalize()
e seja reutilizada após uma chamada paraPy_Initialize()
. Quaisquer problemas decorrentes desse comportamento normalmente resultarão em travamentos durante a execução da chamada subsequente paraPy_Initialize()
ao acessar memória não inicializada. Para corrigir, use um sanitizador de endereços para identificar qualquer uso após liberação proveniente de uma string internalizada e desalocá-la durante o desligamento do módulo. (Contribuição de Eddie Elizondo em gh-113601.)A API C objetos de exceção Unicode agora levanta
TypeError
se o argumento de exceção não for um objetoUnicodeError
. (Contribuição de Bénédikt Tran em gh-127691.)
O interpretador evita internamente algumas modificações na contagem de referências ao carregar objetos na pilha de operandos, pegando emprestadas referências quando possível. Isso pode levar a valores menores de contagem de referências em comparação com versões anteriores do Python. Extensões da API C que verificavam
Py_REFCNT()
de1
para determinar se um argumento de função não é referenciado por nenhum outro código devem, em vez disso, usarPyUnstable_Object_IsUniqueReferencedTemporary()
como uma substituição mais segura.Funções privadas promovidas para APIs C públicas:
_PyBytes_Join()
:PyBytes_Join()
_PyLong_IsNegative()
:PyLong_IsNegative()
_PyLong_IsPositive()
:PyLong_IsPositive()
_PyLong_IsZero()
:PyLong_IsZero()
_PyLong_Sign()
:PyLong_GetSign()
_PyUnicodeWriter_Dealloc()
:PyUnicodeWriter_Discard()
_PyUnicodeWriter_Finish()
:PyUnicodeWriter_Finish()
_PyUnicodeWriter_Init()
: usePyUnicodeWriter_Create()
_PyUnicodeWriter_Prepare()
: (sem substituto)_PyUnicodeWriter_PrepareKind()
: (sem substituto)_PyUnicodeWriter_WriteChar()
:PyUnicodeWriter_WriteChar()
_PyUnicodeWriter_WriteStr()
:PyUnicodeWriter_WriteStr()
_PyUnicodeWriter_WriteSubstring()
:PyUnicodeWriter_WriteSubstring()
_PyUnicode_EQ()
:PyUnicode_Equal()
_PyUnicode_Equal()
:PyUnicode_Equal()
_Py_GetConfig()
:PyConfig_Get()
ePyConfig_GetInt()
_Py_HashBytes()
:Py_HashBuffer()
_Py_fopen_obj()
:Py_fopen()
PyMutex_IsLocked()
:PyMutex_IsLocked()
O projeto pythoncapi-compat pode ser usado para obter a maioria dessas novas funções no Python 3.13 e versões anteriores.