mirror of
https://github.com/postgres/postgres.git
synced 2025-11-19 13:42:17 +03:00
Hand code string to integer conversion for performance.
As benchmarks show, using libc's string-to-integer conversion is pretty slow. At least part of the reason for that is that strtol[l] have to be more generic than what largely is required inside pg. This patch considerably speeds up int2/int4 input (int8 already was already using hand-rolled code). Most of the existing pg_atoi callers have been converted. But as one requires pg_atoi's custom delimiter functionality, and as it seems likely that there's external pg_atoi users, it seems sensible to just keep pg_atoi around. Author: Andres Freund Reviewed-By: Robert Haas Discussion: https://postgr.es/m/20171208214437.qgn6zdltyq5hmjpk@alap3.anarazel.de
This commit is contained in:
@@ -60,7 +60,7 @@ int2in(PG_FUNCTION_ARGS)
|
||||
{
|
||||
char *num = PG_GETARG_CSTRING(0);
|
||||
|
||||
PG_RETURN_INT16(pg_atoi(num, sizeof(int16), '\0'));
|
||||
PG_RETURN_INT16(pg_strtoint16(num));
|
||||
}
|
||||
|
||||
/*
|
||||
@@ -265,7 +265,7 @@ int4in(PG_FUNCTION_ARGS)
|
||||
{
|
||||
char *num = PG_GETARG_CSTRING(0);
|
||||
|
||||
PG_RETURN_INT32(pg_atoi(num, sizeof(int32), '\0'));
|
||||
PG_RETURN_INT32(pg_strtoint32(num));
|
||||
}
|
||||
|
||||
/*
|
||||
|
||||
Reference in New Issue
Block a user