http://www.cnblogs.com/nzbbody/p/3504199.html
来源:互联网 发布:python split 多个空格 编辑:程序博客网 时间:2024/06/05 08:07
C++ int与string的转化
int本身也要用一串字符表示,前后没有双引号,告诉编译器把它当作一个数解释。缺省情况下,是当成10进制(dec)来解释,如果想用8进制,16进制,怎么办?加上前缀,告诉编译器按照不同进制去解释。8进制(oct)---前缀加0,16进制(hex)---前缀加0x或者0X。
string前后加上双引号,告诉编译器把它当成一串字符来解释。
注意:对于字符,需要区分字符和字符表示的数值。比如:char a = 8;char b = '8',a表示第8个字符,b表示字符8,是第56个字符。
int转化为string
1、使用itoa(int to string)
1 //char *itoa( int value, char *string,int radix); 2 // 原型说明: 3 // value:欲转换的数据。 4 // string:目标字符串的地址。 5 // radix:转换后的进制数,可以是10进制、16进制等。 6 // 返回指向string这个字符串的指针 7 8 int aa = 30; 9 char c[8];10 itoa(aa,c,16);11 cout<<c<<endl; // 1e
注意:itoa并不是一个标准的C函数,它是Windows特有的,如果要写跨平台的程序,请用sprintf。
2、使用sprintf
1 // int sprintf( char *buffer, const char *format, [ argument] … ); 2 //参数列表 3 // buffer:char型指针,指向将要写入的字符串的缓冲区。 4 // format:格式化字符串。 5 // [argument]...:可选参数,可以是任何类型的数据。 6 // 返回值:字符串长度(strlen) 7 8 int aa = 30; 9 char c[8]; 10 int length = sprintf(c, "%05X", aa); 11 cout<<c<<endl; // 0001E
3、使用stringstream
1 int aa = 30;2 stringstream ss;3 ss<<aa; 4 string s1 = ss.str();5 cout<<s1<<endl; // 306 7 string s2;8 ss>>s2;9 cout<<s2<<endl; // 30
可以这样理解,stringstream可以吞下不同的类型,根据s2的类型,然后吐出不同的类型。
4、使用boost库中的lexical_cast
1 int aa = 30;2 string s = boost::lexical_cast<string>(aa);3 cout<<s<<endl; // 30
3和4只能转化为10进制的字符串,不能转化为其它进制的字符串。
string转化为int
1、使用strtol(string to long)
1 string s = "17";2 char* end;3 int i = static_cast<int>(strtol(s.c_str(),&end,16));4 cout<<i<<endl; // 235 6 i = static_cast<int>(strtol(s.c_str(),&end,10));7 cout<<i<<endl; // 17
2、使用sscanf
1 int i;2 sscanf("17","%D",&i);3 cout<<i<<endl; // 174 5 sscanf("17","%X",&i);6 cout<<i<<endl; // 237 8 sscanf("0X17","%X",&i);9 cout<<i<<endl; // 23
3、使用stringstream
1 string s = "17";2 3 stringstream ss;4 ss<<s;5 6 int i;7 ss>>i;8 cout<<i<<endl; // 17
注:stringstream可以吞下任何类型,根据实际需要吐出不同的类型。
4、使用boost库中的lexical_cast
1 string s = "17";2 int i = boost::lexical_cast<int>(s);3 cout<<i<<endl; // 17
0 0
- http://www.cnblogs.com/nzbbody/p/3504199.html
- http://www.cnblogs.com/flylovesky/p/3274869.html
- http://www.cnblogs.com/ada-zheng/p/3284660.html
- http://www.cnblogs.com/zhanghaiba/p/3548602.html
- http://www.cnblogs.com/scy251147/p/3566638.html
- http://www.cnblogs.com/amosli/p/3577645.html
- http://www.cnblogs.com/VisualImage/p/3594973.html
- http://www.cnblogs.com/kuangbin/p/3164106.html
- http://www.cnblogs.com/wengzilin/p/3530712.html
- http://www.cnblogs.com/qingjoin/p/3549325.html
- http://www.cnblogs.com/interdrp/p/3785164.html
- http://www.cnblogs.com/ruiati/p/3930732.html
- http://www.cnblogs.com/knowledgesea/p/3491214.html
- http://www.cnblogs.com/ganganloveu/p/3755191.html
- http://www.cnblogs.com/kenshincui/p/3885689.html
- http://www.cnblogs.com/lanxuezaipiao/p/3440471.html
- http://www.cnblogs.com/wangfupeng1988/p/4001284.html
- http://www.cnblogs.com/kissazi2/p/4133927.html
- leetcode(148):Sort List
- Java基础静态方法
- VS2015使用小技巧 控制台代码写完后生成的exe程序在哪里
- Prim算法和Kruskal算法(最小生成树)
- 近期小结
- http://www.cnblogs.com/nzbbody/p/3504199.html
- Java基础方法的初使用规则
- poj 1486 网络流+tarjan
- zigzag数组的C语言实现
- js中typeof的用法
- 主键约束与唯一性约束的区别
- java/android 设计模式学习笔记(19)---状态模式
- CSU 1811 Tree Intersection
- 用网络线程编写的石头剪刀布