亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? wcstol.c

?? C標準庫源代碼,能提高對C的理解,不錯的哦
?? C
字號:
/***
*wcstol.c - Contains C runtimes wcstol and wcstoul
*
*       Copyright (c) 1989-1997, Microsoft Corporation. All rights reserved.
*
*Purpose:
*       wcstol - convert wchar_t string to long signed integer
*       wcstoul - convert wchar_t string to long unsigned integer
*
*******************************************************************************/

#include <cruntime.h>
#include <stdlib.h>
#include <limits.h>
#include <errno.h>
#include <ctype.h>


/***
*wcstol, wcstoul(nptr,endptr,ibase) - Convert ascii string to long un/signed
*       int.
*
*Purpose:
*       Convert an ascii string to a long 32-bit value.  The base
*       used for the caculations is supplied by the caller.  The base
*       must be in the range 0, 2-36.  If a base of 0 is supplied, the
*       ascii string must be examined to determine the base of the
*       number:
*           (a) First char = '0', second char = 'x' or 'X',
*               use base 16.
*           (b) First char = '0', use base 8
*           (c) First char in range '1' - '9', use base 10.
*
*       If the 'endptr' value is non-NULL, then wcstol/wcstoul places
*       a pointer to the terminating character in this value.
*       See ANSI standard for details
*
*Entry:
*       nptr == NEAR/FAR pointer to the start of string.
*       endptr == NEAR/FAR pointer to the end of the string.
*       ibase == integer base to use for the calculations.
*
*       string format: [whitespace] [sign] [0] [x] [digits/letters]
*
*Exit:
*       Good return:
*           result
*
*       Overflow return:
*           wcstol -- LONG_MAX or LONG_MIN
*           wcstoul -- ULONG_MAX
*           wcstol/wcstoul -- errno == ERANGE
*
*       No digits or bad base return:
*           0
*           endptr = nptr*
*
*Exceptions:
*       None.
*******************************************************************************/

/* flag values */
#define FL_UNSIGNED   1       /* wcstoul called */
#define FL_NEG        2       /* negative sign found */
#define FL_OVERFLOW   4       /* overflow occured */
#define FL_READDIGIT  8       /* we've read at least one correct digit */


static unsigned long __cdecl wcstoxl (
        const wchar_t *nptr,
        const wchar_t **endptr,
        int ibase,
        int flags
        )
{
        const wchar_t *p;
        wchar_t c;
        unsigned long number;
        unsigned digval;
        unsigned long maxval;

        p = nptr;           /* p is our scanning pointer */
        number = 0;         /* start with zero */

        c = *p++;           /* read char */
        while (iswspace(c))
            c = *p++;       /* skip whitespace */

        if (c == '-') {
            flags |= FL_NEG;    /* remember minus sign */
            c = *p++;
        }
        else if (c == '+')
            c = *p++;       /* skip sign */

        if (ibase < 0 || ibase == 1 || ibase > 36) {
            /* bad base! */
            if (endptr)
                /* store beginning of string in endptr */
                *endptr = nptr;
            return 0L;      /* return 0 */
        }
        else if (ibase == 0) {
            /* determine base free-lance, based on first two chars of
               string */
            if (c != L'0')
                ibase = 10;
            else if (*p == L'x' || *p == L'X')
                ibase = 16;
            else
                ibase = 8;
        }

        if (ibase == 16) {
            /* we might have 0x in front of number; remove if there */
            if (c == L'0' && (*p == L'x' || *p == L'X')) {
                ++p;
                c = *p++;   /* advance past prefix */
            }
        }

        /* if our number exceeds this, we will overflow on multiply */
        maxval = ULONG_MAX / ibase;


        for (;;) {  /* exit in middle of loop */
            /* convert c to value */
            if (iswdigit(c))
                digval = c - L'0';
            else if (iswalpha(c))
                digval = towupper(c) - L'A' + 10;
            else
                break;
            if (digval >= (unsigned)ibase)
                break;      /* exit loop if bad digit found */

            /* record the fact we have read one digit */
            flags |= FL_READDIGIT;

            /* we now need to compute number = number * base + digval,
               but we need to know if overflow occured.  This requires
               a tricky pre-check. */

            if (number < maxval || (number == maxval &&
            (unsigned long)digval <= ULONG_MAX % ibase)) {
                /* we won't overflow, go ahead and multiply */
                number = number * ibase + digval;
            }
            else {
                /* we would have overflowed -- set the overflow flag */
                flags |= FL_OVERFLOW;
            }

            c = *p++;       /* read next digit */
        }

        --p;                /* point to place that stopped scan */

        if (!(flags & FL_READDIGIT)) {
            /* no number there; return 0 and point to beginning of
               string */
            if (endptr)
                /* store beginning of string in endptr later on */
                p = nptr;
            number = 0L;        /* return 0 */
        }
        else if ( (flags & FL_OVERFLOW) ||
              ( !(flags & FL_UNSIGNED) &&
                ( ( (flags & FL_NEG) && (number > -LONG_MIN) ) ||
                  ( !(flags & FL_NEG) && (number > LONG_MAX) ) ) ) )
        {
            /* overflow or signed overflow occurred */
            errno = ERANGE;
            if ( flags & FL_UNSIGNED )
                number = ULONG_MAX;
            else if ( flags & FL_NEG )
                number = (unsigned long)(-LONG_MIN);
            else
                number = LONG_MAX;
        }

        if (endptr != NULL)
            /* store pointer to char that stopped the scan */
            *endptr = p;

        if (flags & FL_NEG)
            /* negate result if there was a neg sign */
            number = (unsigned long)(-(long)number);

        return number;          /* done. */
}

long __cdecl wcstol (
        const wchar_t *nptr,
        wchar_t **endptr,
        int ibase
        )
{
        return (long) wcstoxl(nptr, endptr, ibase, 0);
}

unsigned long __cdecl wcstoul (
        const wchar_t *nptr,
        wchar_t **endptr,
        int ibase
        )
{
        return wcstoxl(nptr, endptr, ibase, FL_UNSIGNED);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美日韩国产一区二区三区| 欧美日韩国产一区二区三区地区| 一区二区三区影院| 国产日韩三级在线| 欧美精品一区二区三区视频| 色播五月激情综合网| 99久久精品一区二区| 国产成人丝袜美腿| 成人永久aaa| 97精品国产97久久久久久久久久久久 | 激情综合网av| 国产精品一级黄| 福利一区二区在线| 不卡av电影在线播放| 国产成人精品一区二区三区网站观看| 国产99精品国产| 色综合天天综合网国产成人综合天| 国内成+人亚洲+欧美+综合在线| 久久精品国产免费| 成人午夜免费av| 91福利精品第一导航| 欧美色视频一区| 精品国产一区二区三区不卡 | 一区二区久久久| 蜜臀久久99精品久久久久久9| 五月激情综合婷婷| 国产一区二区三区国产| 国产成人无遮挡在线视频| 成人福利在线看| 欧美色窝79yyyycom| 在线综合视频播放| 欧美成人a∨高清免费观看| 久久久精品综合| 亚洲妇女屁股眼交7| 欧美aaa在线| gogo大胆日本视频一区| 欧美色综合天天久久综合精品| 欧美精品日日鲁夜夜添| 26uuu精品一区二区三区四区在线| 国产三级欧美三级日产三级99| 成人免费在线视频| 久久精品国产一区二区三区免费看| 国产一区999| 在线播放91灌醉迷j高跟美女 | 日韩精品成人一区二区三区 | 欧美国产日韩亚洲一区| 亚洲一区在线视频观看| 狠狠狠色丁香婷婷综合久久五月| 国产不卡高清在线观看视频| 91丨porny丨蝌蚪视频| 欧美一区二区二区| 一区二区三区在线观看网站| 亚洲综合999| 99这里只有精品| 久久精品一区二区三区四区| 中文av字幕一区| 国产麻豆精品95视频| 欧美视频一区在线| 亚洲欧美另类在线| 成人av午夜电影| 亚洲国产高清在线观看视频| 一区二区三区四区av| 成人午夜精品一区二区三区| 欧美性猛交xxxxxx富婆| 中文字幕免费一区| 国产在线播放一区二区三区| 91免费观看视频在线| 久久一区二区三区四区| 视频在线观看一区| 欧美日韩色综合| 婷婷久久综合九色综合伊人色| 91视视频在线直接观看在线看网页在线看 | 久久午夜色播影院免费高清| 亚洲欧洲韩国日本视频| 国产原创一区二区三区| 日韩精品中文字幕在线一区| 亚洲欧洲色图综合| 成人高清视频免费观看| 国产色产综合色产在线视频| 日韩中文字幕91| 91精品综合久久久久久| 亚洲高清在线视频| 日韩丝袜情趣美女图片| 天天操天天综合网| 日韩视频免费观看高清完整版在线观看 | 亚洲综合精品久久| 欧美日韩国产高清一区二区三区 | 国产精品一区在线观看你懂的| 欧美久久一二区| 久久黄色级2电影| 久久蜜桃av一区精品变态类天堂| 精品一区二区三区在线播放 | 另类的小说在线视频另类成人小视频在线 | 成人av在线电影| 亚洲一区在线观看视频| 91色九色蝌蚪| 偷窥少妇高潮呻吟av久久免费| 欧美精品一级二级三级| 蜜臀久久99精品久久久久久9| 日韩欧美国产三级电影视频| 日韩av二区在线播放| 精品成人一区二区三区四区| 免费成人在线播放| 国产欧美日韩精品一区| 91香蕉视频污| 久久精工是国产品牌吗| 久久久久国产成人精品亚洲午夜| www.欧美日韩| 日韩av不卡在线观看| 精品国产精品网麻豆系列| 国产成人亚洲综合色影视| 综合网在线视频| 精品乱码亚洲一区二区不卡| 精品一区二区日韩| 亚洲另类色综合网站| 欧美精品1区2区| 91色.com| 国产成人av一区二区| 亚洲小说欧美激情另类| 日韩午夜激情电影| 欧美伊人久久大香线蕉综合69| 性久久久久久久久久久久| 精品久久国产字幕高潮| 在线免费观看成人短视频| 欧美a一区二区| 亚洲sss视频在线视频| 中文字幕精品三区| 精品少妇一区二区三区视频免付费 | 欧美在线视频日韩| 国产 日韩 欧美大片| 亚洲影院久久精品| 136国产福利精品导航| 日韩三级.com| 9191久久久久久久久久久| 国产福利一区二区三区| 七七婷婷婷婷精品国产| 亚洲精品欧美专区| 亚洲天堂久久久久久久| 精品国产免费人成电影在线观看四季| 欧美专区日韩专区| www.66久久| 不卡一卡二卡三乱码免费网站 | 欧美日韩高清一区二区三区| 蜜臀av性久久久久蜜臀aⅴ流畅| 亚洲日本免费电影| 国产精品美女视频| 中文字幕第一区| 国产精品人人做人人爽人人添| 7777精品伊人久久久大香线蕉超级流畅 | 国产传媒日韩欧美成人| 日韩av网站在线观看| 亚洲一区二区欧美日韩| 一区二区三区自拍| 亚洲一卡二卡三卡四卡五卡| 中国av一区二区三区| 久久先锋资源网| 国产精品免费视频一区| 国产日韩欧美精品一区| 久久精品水蜜桃av综合天堂| 欧美放荡的少妇| 精品99一区二区| 欧美精品一区二区三区高清aⅴ| 欧美精品一级二级| 日韩美女一区二区三区| 日韩欧美在线综合网| 欧美一区二区国产| 欧美tickle裸体挠脚心vk| 精品国产三级a在线观看| 精品福利一区二区三区免费视频| 在线播放/欧美激情| 欧美www视频| 国产免费成人在线视频| 中文字幕亚洲精品在线观看| 欧美激情一区二区在线| 欧美激情一区二区三区在线| 久久亚洲欧美国产精品乐播| 日韩一区二区视频| 亚洲国产精品av| 亚洲国产aⅴ成人精品无吗| 日本va欧美va瓶| 成人综合在线网站| 欧美中文字幕一二三区视频| 91福利区一区二区三区| 日韩欧美一区二区免费| 国产欧美日韩视频一区二区| 日本一二三不卡| 午夜视频久久久久久| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产一区二区在线观看视频| 国产永久精品大片wwwapp| aaa欧美大片| 日韩精品中文字幕一区| 国产精品国产三级国产普通话三级 | 在线免费观看日本一区| 欧美一区午夜精品| 亚洲视频一二区| 国内精品国产三级国产a久久| 成人国产精品免费观看动漫| 一本大道久久a久久精二百| 欧美一区二区视频在线观看2020|