]> granicus.if.org Git - python/commitdiff
Issue #21233: Revert bytearray(int) optimization using calloc()
authorVictor Stinner <victor.stinner@gmail.com>
Mon, 2 Jun 2014 20:22:42 +0000 (22:22 +0200)
committerVictor Stinner <victor.stinner@gmail.com>
Mon, 2 Jun 2014 20:22:42 +0000 (22:22 +0200)
Doc/whatsnew/3.5.rst
Misc/NEWS
Objects/bytearrayobject.c

index b879edece4c26c210d49eb4e87a1b4d59cca9f31..5c4e0b56192adc3507bc5c4b4456d7cd3d121b51 100644 (file)
@@ -196,9 +196,8 @@ Optimizations
 
 The following performance enhancements have been added:
 
-* Construction of ``bytes(int)`` and ``bytearray(int)`` (filled by zero bytes)
-  is faster and use less memory (until the bytearray buffer is filled with
-  data) for large objects. ``calloc()`` is used instead of ``malloc()`` to
+* Construction of ``bytes(int)`` (filled by zero bytes) is faster and use less
+  memory for large objects. ``calloc()`` is used instead of ``malloc()`` to
   allocate memory for these objects.
 
 * Some operations on :class:`~ipaddress.IPv4Network` and
index be02bba58a3cc6db8ace25555d4a75f99888723b..af084b86e02335cddae736aa1a0b5f810fb23087 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -26,10 +26,9 @@ Core and Builtins
   internal iteration logic.
 
 - Issue #21233: Add new C functions: PyMem_RawCalloc(), PyMem_Calloc(),
-  PyObject_Calloc(), _PyObject_GC_Calloc(). bytes(int) and bytearray(int)
-  are now using ``calloc()`` instead of ``malloc()`` for large objects which
-  is faster and use less memory (until the bytearray buffer is filled with
-  data).
+  PyObject_Calloc(), _PyObject_GC_Calloc(). bytes(int) is now using
+  ``calloc()`` instead of ``malloc()`` for large objects which is faster and
+  use less memory.
 
 - Issue #21377: PyBytes_Concat() now tries to concatenate in-place when the
   first argument has a reference count of 1.  Patch by Nikolaus Rath.
index 68b9c4a22fa81c4d4be7de22ee72a75420b8bc69..5b75705abff138cb0a91e3d6f699abff9dc919be 100644 (file)
@@ -813,21 +813,9 @@ bytearray_init(PyByteArrayObject *self, PyObject *args, PyObject *kwds)
     }
     else {
         if (count > 0) {
-            void *sval;
-            Py_ssize_t alloc;
-
-            assert (Py_SIZE(self) == 0);
-
-            alloc = count + 1;
-            sval = PyObject_Calloc(1, alloc);
-            if (sval == NULL)
+            if (PyByteArray_Resize((PyObject *)self, count))
                 return -1;
-
-            PyObject_Free(self->ob_bytes);
-
-            self->ob_bytes = self->ob_start = sval;
-            Py_SIZE(self) = count;
-            self->ob_alloc = alloc;
+            memset(PyByteArray_AS_STRING(self), 0, count);
         }
         return 0;
     }