mirror of
https://github.com/python/cpython.git
synced 2025-11-03 03:22:27 +00:00
GvR's idea to use memset() for the most common special case of repeating
a single character. Shaves another 10% off the running time by avoiding the lg2(N) loops and cache effects for the other cases.
This commit is contained in:
parent
2720b0dff8
commit
0a2f849b79
1 changed files with 5 additions and 1 deletions
|
|
@ -966,6 +966,11 @@ string_repeat(register PyStringObject *a, register int n)
|
||||||
PyObject_INIT_VAR(op, &PyString_Type, size);
|
PyObject_INIT_VAR(op, &PyString_Type, size);
|
||||||
op->ob_shash = -1;
|
op->ob_shash = -1;
|
||||||
op->ob_sstate = SSTATE_NOT_INTERNED;
|
op->ob_sstate = SSTATE_NOT_INTERNED;
|
||||||
|
op->ob_sval[size] = '\0';
|
||||||
|
if (a->ob_size == 1 && n > 0) {
|
||||||
|
memset(op->ob_sval, a->ob_sval[0] , n);
|
||||||
|
return (PyObject *) op;
|
||||||
|
}
|
||||||
i = 0;
|
i = 0;
|
||||||
if (i < size) {
|
if (i < size) {
|
||||||
memcpy(op->ob_sval, a->ob_sval, (int) a->ob_size);
|
memcpy(op->ob_sval, a->ob_sval, (int) a->ob_size);
|
||||||
|
|
@ -976,7 +981,6 @@ string_repeat(register PyStringObject *a, register int n)
|
||||||
memcpy(op->ob_sval+i, op->ob_sval, j);
|
memcpy(op->ob_sval+i, op->ob_sval, j);
|
||||||
i += j;
|
i += j;
|
||||||
}
|
}
|
||||||
op->ob_sval[size] = '\0';
|
|
||||||
return (PyObject *) op;
|
return (PyObject *) op;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue