Использование memcpy/memset

При использовании memset или memcpy в программе Obj-C компилятор оптимизирует настройку (memset) или копирование (memcpy) данных в 32-битные записи или будет делать это побайтно?


person Andrew Coad    schedule 24.05.2010    source источник
comment
Я сомневаюсь, что есть какая-либо современная реализация, которая делала бы это байт за байтом, за исключением особых случаев, таких как проблемы с выравниванием и т. д.   -  person Ofir    schedule 24.05.2010


Ответы (2)


Вы можете увидеть реализации libc этих методов в Источник Дарвина. В версии 10.6.3 memset работает на уровне слов. Я не проверял memcpy, но, вероятно, это то же самое.

Вы правы в том, что компилятор может выполнять работу встроенно, а не вызывать эти функции. Я полагаю, я позволю тому, кто знает лучше, ответить, что он будет делать, хотя я не ожидаю проблем.

person Ken    schedule 24.05.2010

Memset станет частью вашей стандартной библиотеки C, поэтому это зависит от используемой вами реализации. Я предполагаю, что большинство реализаций будут копировать блоки собственного размера ЦП (32/64 бита), а затем оставшуюся часть побайтно.

Вот версия memcpy от glibc для примера реализации:

void *
memcpy (dstpp, srcpp, len)
     void *dstpp;
     const void *srcpp;
     size_t len;
{
  unsigned long int dstp = (long int) dstpp;
  unsigned long int srcp = (long int) srcpp;

  /* Copy from the beginning to the end.  */

  /* If there not too few bytes to copy, use word copy.  */
  if (len >= OP_T_THRES)
    {
      /* Copy just a few bytes to make DSTP aligned.  */
      len -= (-dstp) % OPSIZ;
      BYTE_COPY_FWD (dstp, srcp, (-dstp) % OPSIZ);

      /* Copy whole pages from SRCP to DSTP by virtual address manipulation,
     as much as possible.  */

      PAGE_COPY_FWD_MAYBE (dstp, srcp, len, len);

      /* Copy from SRCP to DSTP taking advantage of the known alignment of
     DSTP.  Number of bytes remaining is put in the third argument,
     i.e. in LEN.  This number may vary from machine to machine.  */

      WORD_COPY_FWD (dstp, srcp, len, len);

      /* Fall out and copy the tail.  */
    }

  /* There are just a few bytes to copy.  Use byte memory operations.  */
  BYTE_COPY_FWD (dstp, srcp, len);

  return dstpp;
}

Таким образом, вы можете видеть, что он сначала копирует несколько байтов для выравнивания, затем копирует слова, а затем, наконец, снова байты. Он выполняет оптимизированное копирование страниц, используя некоторые операции ядра.

person Mike Weller    schedule 24.05.2010