Objetos MemoryView¶
Um objeto memoryview
expõe a interface de buffer a nível de C como um objeto Python que pode ser passado como qualquer outro objeto.
-
PyObject *PyMemoryView_FromObject(PyObject *obj)¶
- Retorna valor: Nova referência. Parte da ABI Estável.
Cria um objeto memoryview a partir de um objeto que fornece a interface do buffer. Se obj tiver suporte a exportações de buffer graváveis, o objeto memoryview será de leitura/gravação; caso contrário, poderá ser somente leitura ou leitura/gravação, a critério do exportador.
-
PyBUF_READ¶
Sinalizador para solicitar um buffer de somente leitura.
-
PyBUF_WRITE¶
Sinalizador para solicitar um buffer gravável.
-
PyObject *PyMemoryView_FromMemory(char *mem, Py_ssize_t size, int flags)¶
- Retorna valor: Nova referência. Parte da ABI Estável desde a versão 3.7.
Cria um objeto memoryview usando mem como o buffer subjacente. flags pode ser um dos seguintes
PyBUF_READ
ouPyBUF_WRITE
.Novo na versão 3.3.
-
PyObject *PyMemoryView_FromBuffer(const Py_buffer *view)¶
- Retorna valor: Nova referência. Parte da ABI Estável desde a versão 3.11.
Cria um objeto de memoryview envolvendo a estrutura de buffer view fornecida. Para buffers de bytes simples,
PyMemoryView_FromMemory()
é a função preferida.
-
PyObject *PyMemoryView_GetContiguous(PyObject *obj, int buffertype, char order)¶
- Retorna valor: Nova referência. Parte da ABI Estável.
Cria um objeto memoryview para um pedaço contíguo de memória (na ordem ‘C’ ou ‘F’ortran, representada por order) a partir de um objeto que define a interface do buffer. Se a memória for contígua, o objeto memoryview apontará para a memória original. Caso contrário, é feita uma cópia e a visualização da memória aponta para um novo objeto bytes.
buffertype pode ser um entre
PyBUF_READ
ouPyBUF_WRITE
.
-
int PyMemoryView_Check(PyObject *obj)¶
Retorna true se o objeto obj for um objeto memoryview. Atualmente, não é permitido criar subclasses de
memoryview
. Esta função sempre tem sucesso.
-
Py_buffer *PyMemoryView_GET_BUFFER(PyObject *mview)¶
Retorna um ponteiro para a cópia privada da memória do buffer do exportador. mview deve ser uma instância de memoryview; Se essa macro não verificar seu tipo, faça você mesmo ou corre o risco de travar.
-
PyObject *PyMemoryView_GET_BASE(PyObject *mview)¶
Retorna um ponteiro para o objeto de exportação no qual a memória é baseada ou
NULL
se a memória tiver sido criada por uma das funçõesPyMemoryView_FromMemory()
ouPyMemoryView_FromBuffer()
. mview deve ser uma instância de memoryview.