The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]



"Для ядра Linux предложена реализация функции memchr, работающая до 4 раз быстрее"
Версия для распечатки Пред. тема | След. тема
Форум Разговоры, обсуждение новостей
Исходное сообщение [ Отслеживать ]
Подсказка: Для контроля за появлением новых сообщений - перед выходом жмите "Пометить прочитанным".
. "Для ядра Linux предложена реализация функции memchr, работаю..." +/
Сообщение от n00by (ok), 13-Июл-22, 19:40 
Да, опция для другого. Задействованный механизм позволяет иногда оптимизировать чуть лучше:

$ cat test.c
#include <string.h>

int test(const char* s)
{
  return strlen(s) == 5;
}

int main()
{
  return test("12345");
}

$ gcc -o test.s test.c -S -O2
$ cat test.s

test:
    subq    $8, %rsp
    call    strlen@PLT
    cmpq    $5, %rax
    sete    %al
    addq    $8, %rsp
    movzbl    %al, %eax
    ret

main:
    movl    $1, %eax // strlen вообще не вызывается
    ret


В асм листинге вырезал нерелевантный текст.

То, что Вы предлагаете - это не наивная оптимизация. Подсчёт кол-ва символов в строке помещает всю строку в кеш. Если её длина больше 5 - может именно это программисту и надо?

Ответить | Правка | Наверх | Cообщить модератору

Оглавление
Для ядра Linux предложена реализация функции memchr, работающая до 4 раз быстрее, opennews, 12-Июл-22, 09:26  [смотреть все]
Форумы | Темы | Пред. тема | След. тема



Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2024 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру