Kaydet (Commit) 0a2f849b authored tarafından Raymond Hettinger's avatar Raymond Hettinger

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.
üst 2720b0df
......@@ -966,6 +966,11 @@ string_repeat(register PyStringObject *a, register int n)
PyObject_INIT_VAR(op, &PyString_Type, size);
op->ob_shash = -1;
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;
if (i < 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);
i += j;
}
op->ob_sval[size] = '\0';
return (PyObject *) op;
}
......
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