Kaydet (Commit) 2bc4d95b authored tarafından Victor Stinner's avatar Victor Stinner

Issue #21233: Revert bytearray(int) optimization using calloc()

üst d8f0d922
...@@ -196,9 +196,8 @@ Optimizations ...@@ -196,9 +196,8 @@ Optimizations
The following performance enhancements have been added: The following performance enhancements have been added:
* Construction of ``bytes(int)`` and ``bytearray(int)`` (filled by zero bytes) * Construction of ``bytes(int)`` (filled by zero bytes) is faster and use less
is faster and use less memory (until the bytearray buffer is filled with memory for large objects. ``calloc()`` is used instead of ``malloc()`` to
data) for large objects. ``calloc()`` is used instead of ``malloc()`` to
allocate memory for these objects. allocate memory for these objects.
* Some operations on :class:`~ipaddress.IPv4Network` and * Some operations on :class:`~ipaddress.IPv4Network` and
......
...@@ -26,10 +26,9 @@ Core and Builtins ...@@ -26,10 +26,9 @@ Core and Builtins
internal iteration logic. internal iteration logic.
- Issue #21233: Add new C functions: PyMem_RawCalloc(), PyMem_Calloc(), - Issue #21233: Add new C functions: PyMem_RawCalloc(), PyMem_Calloc(),
PyObject_Calloc(), _PyObject_GC_Calloc(). bytes(int) and bytearray(int) PyObject_Calloc(), _PyObject_GC_Calloc(). bytes(int) is now using
are now using ``calloc()`` instead of ``malloc()`` for large objects which ``calloc()`` instead of ``malloc()`` for large objects which is faster and
is faster and use less memory (until the bytearray buffer is filled with use less memory.
data).
- Issue #21377: PyBytes_Concat() now tries to concatenate in-place when the - Issue #21377: PyBytes_Concat() now tries to concatenate in-place when the
first argument has a reference count of 1. Patch by Nikolaus Rath. first argument has a reference count of 1. Patch by Nikolaus Rath.
......
...@@ -813,21 +813,9 @@ bytearray_init(PyByteArrayObject *self, PyObject *args, PyObject *kwds) ...@@ -813,21 +813,9 @@ bytearray_init(PyByteArrayObject *self, PyObject *args, PyObject *kwds)
} }
else { else {
if (count > 0) { if (count > 0) {
void *sval; if (PyByteArray_Resize((PyObject *)self, count))
Py_ssize_t alloc;
assert (Py_SIZE(self) == 0);
alloc = count + 1;
sval = PyObject_Calloc(1, alloc);
if (sval == NULL)
return -1; return -1;
memset(PyByteArray_AS_STRING(self), 0, count);
PyObject_Free(self->ob_bytes);
self->ob_bytes = self->ob_start = sval;
Py_SIZE(self) = count;
self->ob_alloc = alloc;
} }
return 0; return 0;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment