Или комбинация двух подходов:
_Bool starts_with(const char *restrict string, const char *restrict prefix)
{
char * const restrict prefix_end = prefix + 13;
while (1)
{
if ( 0 == *prefix )
return 1;
if ( *prefix++ != *string++)
return 0;
if ( prefix_end <= prefix )
return 0 == strncmp(prefix, string, strlen(prefix));
}
}
РЕДАКТИРОВАТЬ: приведенный ниже код НЕ работает, потому что, если strncmp возвращает 0, неизвестно, был ли достигнут завершающий 0 или длина (block_size).
Дополнительная идея - сравнивать по блокам. Если блок не равен, сравните этот блок с исходной функцией:
_Bool starts_with_big(const char *restrict string, const char *restrict prefix)
{
size_t block_size = 64;
while (1)
{
if ( 0 != strncmp( string, prefix, block_size ) )
return starts_with( string, prefix);
string += block_size;
prefix += block_size;
if ( block_size < 4096 )
block_size *= 2;
}
}
Константы 13
, 64
, 4096
, а также потенциированиеblock_size
лишь догадки. Его нужно будет выбрать для используемых входных данных и оборудования.