Namespaces
Variants

wcstof, wcstod, wcstold

From cppreference.net
< c ‎ | string ‎ | wide
定义于头文件 <wchar.h>
float wcstof ( const wchar_t * restrict str, wchar_t ** restrict str_end ) ;
(C99 起)
double wcstod ( const wchar_t * str, wchar_t ** str_end ) ;
(C95 起)
(C99 前)
double wcstod ( const wchar_t * restrict str, wchar_t ** restrict str_end ) ;
(C99 起)
long double wcstold ( const wchar_t * restrict str, wchar_t ** restrict str_end ) ;
(C99 起)

str 所指向的宽字符串中的浮点值进行解析。

函数会丢弃所有空白字符(由 iswspace 确定),直至找到首个非空白字符。随后尽可能提取组成有效浮点数表示的字符,并将其转换为浮点数值。有效的浮点数值可以是以下任意一种形式:

  • 十进制浮点表达式。它由以下部分组成:
  • (可选) 正负号
  • 非空的十进制数字序列,可选包含小数点字符(由当前C语言 区域设置 决定)(定义有效数字)
  • (可选) e E 后接可选减号或加号以及非空的十进制数字序列(定义以 10 为底的指数)
  • 十六进制浮点表达式。由以下部分组成:
  • (可选) 正负号
  • 0x 0X
  • 非空的十六进制数字序列,可包含由当前C语言 区域设置 决定的小数点字符(定义有效数)
  • (可选) p P 后接可选减号或加号以及非空的十进制数字序列(定义以 2 为底的指数)
  • 无穷大表达式。由以下部分组成:
  • (可选) 正负号
  • 不区分大小写的 INF INFINITY
  • 非数值表达式。由以下部分组成:
  • (可选) 正负号
  • 不区分 NAN 部分大小写的 NAN NAN( 字符序列  ) 字符序列 只能包含数字、拉丁字母和下划线。结果为静默NaN浮点值。
(C99起)
  • 任何其他可能被当前安装的 C locale 接受的表达式。

该函数将 str_end 所指向的指针设置为指向最后一个被解释宽字符之后的位置。如果 str_end 是空指针,则此参数将被忽略。

目录

参数

str - 指向要解析的空终止宽字符串的指针
str_end - 指向宽字符指针的指针

返回值

成功时返回与 str 内容对应的浮点数值。若转换值超出对应返回类型的范围,则发生范围错误并返回 HUGE_VAL HUGE_VALF HUGE_VALL 。若无法执行转换,则返回 0

示例

#include <errno.h>
#include <stdio.h>
#include <wchar.h>
int main(void)
{
    const wchar_t* p = L"111.11 -2.22 0X1.BC70A3D70A3D7P+6  1.18973e+4932zzz";
    printf("Parsing L\"%ls\":\n", p);
    wchar_t* end;
    for (double f = wcstod(p, &end); p != end; f = wcstod(p, &end))
    {
        printf("'%.*ls' -> ", (int)(end-p), p);
        p = end;
        if (errno == ERANGE){
            printf("range error, got ");
            errno = 0;
        }
        printf("%f\n", f);
    }
}

输出:

Parsing L"111.11 -2.22 0X1.BC70A3D70A3D7P+6  1.18973e+4932zzz":
'111.11' -> 111.110000
' -2.22' -> -2.220000
' 0X1.BC70A3D70A3D7P+6' -> 111.110000
'  1.18973e+4932' -> range error, got inf

参考文献

  • C23 标准 (ISO/IEC 9899:2024):
  • 7.29.4.1.1 wcstod、wcstof 和 wcstold 函数 (p: TBD)
  • C17 标准 (ISO/IEC 9899:2018):
  • 7.29.4.1.1 wcstod、wcstof 和 wcstold 函数 (页: TBD)
  • C11 标准 (ISO/IEC 9899:2011):
  • 7.29.4.1.1 wcstod、wcstof 和 wcstold 函数 (页码: 426-428)
  • C99标准(ISO/IEC 9899:1999):
  • 7.24.4.1.1 wcstod、wcstof和wcstold函数(页码:372-374)

参考

将字节字符串转换为浮点值
(函数)
C++ 文档 关于 wcstof , wcstod , wcstold