mirror of
				https://github.com/python/cpython.git
				synced 2025-11-03 23:21:29 +00:00 
			
		
		
		
	Issue #21233: Revert bytearray(int) optimization using calloc()
This commit is contained in:
		
							parent
							
								
									d8f0d922d5
								
							
						
					
					
						commit
						2bc4d95bb6
					
				
					 3 changed files with 7 additions and 21 deletions
				
			
		| 
						 | 
					@ -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
 | 
				
			||||||
  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)
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    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;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue