strings.h и переносящий этот макрос с макро-проверкой ли

Нажмите на имя метода тестирования, затем нажмите Ctrl+R, Ctrl+T. (Или перейдите к Тесту / Отладка / Тесты в Текущем Контексте.)

6
задан stanigator 30 October 2009 в 02:43
поделиться

2 ответа

Один из вариантов:

#ifndef _WIN32
#include <strings.h>
#endif

Согласно MSDN , _WIN32 «определен для приложений для Win32 и Win64. Всегда определяется».

Компилятор или стандартная библиотека для операционной системы, отличной от Windows, конечно, может свободно определять _WIN32 , но это было бы ... очень необычно.

2
ответ дан 17 December 2019 в 00:11
поделиться

strings.h содержит только несколько функций, большинство из которых являются просто разными именами для функций из стандартной библиотеки (например, bcmp () < -> memcmp () ). Если ваш код использует эти функции, вместо того, чтобы бросать #ifdef , почему бы просто не написать свой собственный набор?

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

Вот еще не полностью протестированный набор общедоступных функций, которые вы можете использовать на свой страх и риск:

#include <string.h>
#include <ctype.h>

int bcmp(const void * p1, const void * p2, size_t n)
{
    return memcmp( p1, p2, n);
}

void   bcopy(const void * src, void * dst, size_t n)
{
    memmove( dst, src, n);  /* note different order of args - yuck */
}

void   bzero(void * p, size_t n)
{
    memset( p, 0, n);
}

char   *index(const char * s, int c)
{
    return strchr( s, c);
}

char   *rindex(const char * s, int c)
{
    return strrchr( s, c);
}

int    strcasecmp(const char* s1, const char* s2)
{
    for (;;) {
        int c1 = tolower( *((unsigned char*) s1++));
        int c2 = tolower( *((unsigned char*) s2++));

        if ((c1 != c2) || (c1 == '\0')) {
            return( c1 - c2);
        }
    }
}

int    strncasecmp(const char* s1, const char* s2, size_t n)
{
    for (; n != 0; --n) {
        int c1 = tolower( *((unsigned char*) s1++));
        int c2 = tolower( *((unsigned char*) s2++));

        if ((c1 != c2) || (c1 == '\0')) {
            return( c1 - c2);
        }
    }

    return( 0);
}


int    ffs(int v)
{
    unsigned int x = v;
    int c = 1;

    /* 
     * adapted from from 
     *      http://graphics.stanford.edu/~seander/bithacks.html#ZerosOnRightBinSearch
     *
     * a modified binary search algorithm to count 0 bits from 
     *  the right (lsb).  This algorithm should work regardless 
     *  of the size of ints on the platform.
     *
     */

    /* a couple special cases */
    if (x == 0) return 0;
    if (x & 1)  return 1;   /* probably pretty common */

    c = 1;
    while ((x & 0xffff) == 0) {
        x >>= 16;
        c +=  16;
    }
    if ((x & 0xff) == 0) {
        x >>= 8;
        c +=  8;
    }
    if ((x & 0x0f) == 0) {
        x >>= 4;
        c +=  4;
    }
    if ((x & 0x03) == 0) {
        x >>= 2;
        c +=  2;
    }

    c -= (x & 1);
    c += 1;     /* ffs() requires indexing bits from 1 */
                /*   ie., the lsb is bit 1, not bit 0  */
    return c;
}
5
ответ дан 17 December 2019 в 00:11
поделиться
Другие вопросы по тегам:

Похожие вопросы: