简体   繁体   English

std :: lexical_cast-有这样的事情吗?

[英]std::lexical_cast - is there such a thing?

Does the C++ Standard Library define this function, or do I have to resort to Boost? C ++标准库是否定义了此功能,还是我必须诉诸Boost?

I searched the web and couldn't find anything except Boost, but I thought I'd better ask here. 我在网上搜索,除了Boost以外什么都找不到,但是我想最好在这里问一下。

Only partially. 仅部分。

C++11 <string> has std::to_string for the built-in types: C ++ 11 <string>具有内置类型的std::to_string

[n3290: 21.5/7]:

 string to_string(int val); string to_string(unsigned val); string to_string(long val); string to_string(unsigned long val); string to_string(long long val); string to_string(unsigned long long val); string to_string(float val); string to_string(double val); string to_string(long double val); 

Returns: Each function returns a string object holding the character representation of the value of its argument that would be generated by calling sprintf(buf, fmt, val) with a format specifier of "%d" , "%u" , "%ld" , "%lu" , "%lld" , "%llu" , "%f" , "%f" , or "%Lf" , respectively, where buf designates an internal character buffer of sufficient size. 返回值:每个函数都返回一个string对象,其中包含其参数值的字符表示,该string值可通过调用格式为"%d""%u""%ld" "%u" sprintf(buf, fmt, val)生成"%ld""%lu""%lld""%llu""%f""%f""%Lf" ,其中buf表示足够大的内部字符缓冲区。

There are also the following that go the other way around: 还有其他一些方法:

[n3290: 21.5/1, 21.5/4]:

 int stoi(const string& str, size_t *idx = 0, int base = 10); long stol(const string& str, size_t *idx = 0, int base = 10); unsigned long stoul(const string& str, size_t *idx = 0, int base = 10); long long stoll(const string& str, size_t *idx = 0, int base = 10); unsigned long long stoull(const string& str, size_t *idx = 0, int base = 10); float stof(const string& str, size_t *idx = 0); double stod(const string& str, size_t *idx = 0); long double stold(const string& str, size_t *idx = 0); 

However, there's nothing generic that you can use (at least not until TR2 , maybe!), and nothing at all in C++03. 但是,没有任何泛型可以使用(至少要等到TR2才可以使用!),而在C ++ 03中则什么也没有。

不,即使在C ++ 11中也不是,但是建议将其包含在技​​术报告2中,这是下一整套std库扩展。

There's no std::lexical_cast, but you can always do something similar with stringstreams : 没有std :: lexical_cast,但是您始终可以对stringstreams做类似的事情:

template <typename T>
T lexical_cast(const std::string& str)
{
    T var;
    std::istringstream iss;
    iss.str(str);
    iss >> var;
    // deal with any error bits that may have been set on the stream
    return var;
}

不,这只是纯粹的Boost。

If you don't want boost then a lightweight library called fmt implements the following: 如果您不希望升压,那么一个名为fmt的轻量级库将实现以下内容:

// Works with all the C++11 features and AFAIK faster then boost or standard c++11
std::string string_num = fmt::format_int(123456789).str(); // or .c_str()

More examples from the official page . 官方页面上有更多示例。

Accessing arguments by position: 按位置访问参数:

format("{0}, {1}, {2}", 'a', 'b', 'c');
// Result: "a, b, c"
format("{}, {}, {}", 'a', 'b', 'c');
// Result: "a, b, c"
format("{2}, {1}, {0}", 'a', 'b', 'c');
// Result: "c, b, a"
format("{0}{1}{0}", "abra", "cad");  // arguments' indices can be repeated
// Result: "abracadabra"

Aligning the text and specifying a width: 对齐文本并指定宽度:

format("{:<30}", "left aligned");
// Result: "left aligned                  "
format("{:>30}", "right aligned");
// Result: "                 right aligned"
format("{:^30}", "centered");
// Result: "           centered           "
format("{:*^30}", "centered");  // use '*' as a fill char
// Result: "***********centered***********"

Replacing %+f, %-f, and % f and specifying a sign: 替换%+ f,%-f和%f并指定一个符号:

format("{:+f}; {:+f}", 3.14, -3.14);  // show it always
// Result: "+3.140000; -3.140000"
format("{: f}; {: f}", 3.14, -3.14);  // show a space for positive numbers
// Result: " 3.140000; -3.140000"
format("{:-f}; {:-f}", 3.14, -3.14);  // show only the minus -- same as '{:f}; {:f}'
// Result: "3.140000; -3.140000"

Replacing %x and %o and converting the value to different bases: 替换%x和%o并将值转换为不同的基数:

format("int: {0:d};  hex: {0:x};  oct: {0:o}; bin: {0:b}", 42);
// Result: "int: 42;  hex: 2a;  oct: 52; bin: 101010"
// with 0x or 0 or 0b as prefix:
format("int: {0:d};  hex: {0:#x};  oct: {0:#o};  bin: {0:#b}", 42);
// Result: "int: 42;  hex: 0x2a;  oct: 052;  bin: 0b101010"

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM