C++ int与string的相互转换(含源码实现)

C++ int与string的相互转换(含源码实现)一、int转换成stringⅠ、to_string函数c++11标准增加了全局函数std::to_string:stringto_string(intval);stringto_str

大家好,又见面了,我是你们的朋友全栈君。

一、int转换成string

  Ⅰ、to_string函数

c++11标准增加了全局函数std::to_string:

string to_string (int val);

string to_string (long val);

string to_string (long long val);

string to_string (unsigned val);

string to_string (unsigned 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);

Example:

 1 // to_string example  
 2 #include <iostream>   // std::cout  
 3 #include <string>     // std::string, std::to_string  
 4   
 5 int main ()  
 6 {  
 7   std::string pi = "pi is " + std::to_string(3.1415926);  
 8   std::string perfect = std::to_string(1+2+4+7+14) + " is a perfect number";  
 9   std::cout << pi << '\n';  
10   std::cout << perfect << '\n';  
11   return 0;  
12 } 
13 Output
14 pi is 3.141593  
15 28 is a perfect number 

 附:to_string()函数的实现

 1 //实现to_string函数
 2 #include<iostream>
 3 #include<string>
 4 using namespace std;
 5 #define max 100
 6 string to_String(int n)
 7 {
 8     int m = n;
 9     char s[max];
10     char ss[max];
11     int i=0,j=0;
12     if (n < 0)// 处理负数
13     {
14         m = 0 - m;
15         j = 1;
16         ss[0] = '-';
17     }    
18     while (m>0)
19     {
20         s[i++] = m % 10 + '0';
21         m /= 10;
22     }
23     s[i] = '
 1 //实现to_string函数  2 #include<iostream>  3 #include<string>  4 using namespace std;  5 #define max 100  6 string to_String(int n)  7 {  8 int m = n;  9 char s[max]; 10 char ss[max]; 11 int i=0,j=0; 12 if (n < 0)// 处理负数 13  { 14 m = 0 - m; 15 j = 1; 16 ss[0] = '-'; 17  } 18 while (m>0) 19  { 20 s[i++] = m % 10 + '0'; 21 m /= 10; 22  } 23 s[i] = '\0'; 24 i = i - 1; 25 while (i >= 0) 26  { 27 ss[j++] = s[i--]; 28  } 29 ss[j] = '\0'; 30 return ss; 31 } 32 33 int main() 34 { 35 cout << "请输入整数:"; 36 int m; 37 cin >> m; 38 string s = to_String(m) + "abc"; 39 cout << s << endl; 40 system("pause"); 41 return 0; 42 }
'; 24 i = i - 1; 25 while (i >= 0) 26 { 27 ss[j++] = s[i--]; 28 } 29 ss[j] = '
 1 //实现to_string函数  2 #include<iostream>  3 #include<string>  4 using namespace std;  5 #define max 100  6 string to_String(int n)  7 {  8 int m = n;  9 char s[max]; 10 char ss[max]; 11 int i=0,j=0; 12 if (n < 0)// 处理负数 13  { 14 m = 0 - m; 15 j = 1; 16 ss[0] = '-'; 17  } 18 while (m>0) 19  { 20 s[i++] = m % 10 + '0'; 21 m /= 10; 22  } 23 s[i] = '\0'; 24 i = i - 1; 25 while (i >= 0) 26  { 27 ss[j++] = s[i--]; 28  } 29 ss[j] = '\0'; 30 return ss; 31 } 32 33 int main() 34 { 35 cout << "请输入整数:"; 36 int m; 37 cin >> m; 38 string s = to_String(m) + "abc"; 39 cout << s << endl; 40 system("pause"); 41 return 0; 42 }
'; 30 return ss; 31 } 32 33 int main() 34 { 35 cout << "请输入整数:"; 36 int m; 37 cin >> m; 38 string s = to_String(m) + "abc"; 39 cout << s << endl; 40 system("pause"); 41 return 0; 42 }

 

 Ⅱ、借助字符串流

  标准库定义了三种类型字符串流:istringstream,ostringstream,stringstream,看名字就知道这几种类型和iostream中的几个非常类似,分别可以读、写以及读和写string类型,它们也确实是从iostream类型派生而来的。要使用它们需要包含sstream头文件。

除了从iostream继承来的操作

  1.sstream类型定义了一个有string形参的构造函数,即:  stringstream stream(s); 创建了存储s副本的stringstream对象,s为string类型对象

  2.定义了名为str的成员,用来读取或设置stringstream对象所操纵的string值:stream.str(); 返回stream中存储的string类型对象stream.str(s); 将string类型的s复制给stream,返回void

Example:

1 int aa = 30;
2 stringstream ss;
3 ss<<aa; 
4 string s1 = ss.str();
5 cout<<s1<<endl; // 30

二、string转换成int

  Ⅰ、采用标准库中atoi函数,对于其他类型也都有相应的标准库函数,比如浮点型atof(),long型atol()等等

Example:

1 std::string str = "123";
2 int n = atoi(str.c_str());
3 cout<<n; //123

 附:atoi()函数的源码实现

  这个函数的主要功能是将一个字符串转化为一个数字,可能第一眼看上去,你会觉得这是一个很简单的函数,甚至是一个不需要多少行代码就可以实现的函数。其实这是一个看着很简单,但是实践起来还有些需要注意的地方。总的来说,有以下5种情况:

1–指针为NULL
2–空字符处理
3–正号与负号的处理
4–溢出处理
5–如果遇到异常字符怎么处理

下面附上代码:

 

#include<iostream>
enum ret { kvalid=0,kinvalid };    // 是否有非法输入的标记
int status = kvalid;
long long Strtointcode(const char* digit, bool minus)
{
    long long num = 0;
    while (*digit != '
#include<iostream> enum ret { kvalid=0,kinvalid }; // 是否有非法输入的标记 int status = kvalid; long long Strtointcode(const char* digit, bool minus) { long long num = 0; while (*digit != '\0') { if (*digit >= '0'&&*digit <= '9') { int flag = minus ? -1 : 1; num = num * 10 + flag*(*digit - '0'); if ((!minus&&num > 0x7FFFFFFF) ||( minus&&num < (signed int)0x80000000)) { num = 0; break; } digit++; } else { num = 0; break; } } if (*digit == '\0') status = kvalid; return num; } int Strtoint(const char* str) { status = kinvalid; long long num = 0; if (str != NULL&&*str != '\0') { bool minus = false; if (*str == '+') str++; else if (*str == '-') { str++; minus = true; } if (*str != '\0') num = Strtointcode(str, minus); } return (int)num; } int main() { char arr[20]; int ret = 0; printf("请输入您要转化的字符串:\n"); scanf("%s", arr); ret = Strtoint(arr); if (kvalid == status) { printf("%d\n", ret); } else { printf("输入非法\n"); printf("%d\n", ret); } system("pause"); return 0; }
') { if (*digit >= '0'&&*digit <= '9') { int flag = minus ? -1 : 1; num = num * 10 + flag*(*digit - '0'); if ((!minus&&num > 0x7FFFFFFF) ||( minus&&num < (signed int)0x80000000)) { num = 0; break; } digit++; } else { num = 0; break; } } if (*digit == '
#include<iostream> enum ret { kvalid=0,kinvalid }; // 是否有非法输入的标记 int status = kvalid; long long Strtointcode(const char* digit, bool minus) { long long num = 0; while (*digit != '\0') { if (*digit >= '0'&&*digit <= '9') { int flag = minus ? -1 : 1; num = num * 10 + flag*(*digit - '0'); if ((!minus&&num > 0x7FFFFFFF) ||( minus&&num < (signed int)0x80000000)) { num = 0; break; } digit++; } else { num = 0; break; } } if (*digit == '\0') status = kvalid; return num; } int Strtoint(const char* str) { status = kinvalid; long long num = 0; if (str != NULL&&*str != '\0') { bool minus = false; if (*str == '+') str++; else if (*str == '-') { str++; minus = true; } if (*str != '\0') num = Strtointcode(str, minus); } return (int)num; } int main() { char arr[20]; int ret = 0; printf("请输入您要转化的字符串:\n"); scanf("%s", arr); ret = Strtoint(arr); if (kvalid == status) { printf("%d\n", ret); } else { printf("输入非法\n"); printf("%d\n", ret); } system("pause"); return 0; }
') status = kvalid; return num; } int Strtoint(const char* str) { status = kinvalid; long long num = 0; if (str != NULL&&*str != '
#include<iostream> enum ret { kvalid=0,kinvalid }; // 是否有非法输入的标记 int status = kvalid; long long Strtointcode(const char* digit, bool minus) { long long num = 0; while (*digit != '\0') { if (*digit >= '0'&&*digit <= '9') { int flag = minus ? -1 : 1; num = num * 10 + flag*(*digit - '0'); if ((!minus&&num > 0x7FFFFFFF) ||( minus&&num < (signed int)0x80000000)) { num = 0; break; } digit++; } else { num = 0; break; } } if (*digit == '\0') status = kvalid; return num; } int Strtoint(const char* str) { status = kinvalid; long long num = 0; if (str != NULL&&*str != '\0') { bool minus = false; if (*str == '+') str++; else if (*str == '-') { str++; minus = true; } if (*str != '\0') num = Strtointcode(str, minus); } return (int)num; } int main() { char arr[20]; int ret = 0; printf("请输入您要转化的字符串:\n"); scanf("%s", arr); ret = Strtoint(arr); if (kvalid == status) { printf("%d\n", ret); } else { printf("输入非法\n"); printf("%d\n", ret); } system("pause"); return 0; }
') { bool minus = false; if (*str == '+') str++; else if (*str == '-') { str++; minus = true; } if (*str != '
#include<iostream> enum ret { kvalid=0,kinvalid }; // 是否有非法输入的标记 int status = kvalid; long long Strtointcode(const char* digit, bool minus) { long long num = 0; while (*digit != '\0') { if (*digit >= '0'&&*digit <= '9') { int flag = minus ? -1 : 1; num = num * 10 + flag*(*digit - '0'); if ((!minus&&num > 0x7FFFFFFF) ||( minus&&num < (signed int)0x80000000)) { num = 0; break; } digit++; } else { num = 0; break; } } if (*digit == '\0') status = kvalid; return num; } int Strtoint(const char* str) { status = kinvalid; long long num = 0; if (str != NULL&&*str != '\0') { bool minus = false; if (*str == '+') str++; else if (*str == '-') { str++; minus = true; } if (*str != '\0') num = Strtointcode(str, minus); } return (int)num; } int main() { char arr[20]; int ret = 0; printf("请输入您要转化的字符串:\n"); scanf("%s", arr); ret = Strtoint(arr); if (kvalid == status) { printf("%d\n", ret); } else { printf("输入非法\n"); printf("%d\n", ret); } system("pause"); return 0; }
') num = Strtointcode(str, minus); } return (int)num; } int main() { char arr[20]; int ret = 0; printf("请输入您要转化的字符串:\n"); scanf("%s", arr); ret = Strtoint(arr); if (kvalid == status) { printf("%d\n", ret); } else { printf("输入非法\n"); printf("%d\n", ret); } system("pause"); return 0; }

 

 

 Ⅱ、采用sstream头文件中定义的字符串流对象来实现转换

1 istringstream is("12"); //构造输入字符串流,流的内容初始化为“12”的字符串   
2 int i;   
3 is >> i; //从is流中读入一个int整数存入i中  

 

参考资料:

http://blog.csdn.net/loving_forever_/article/details/51285703

http://blog.csdn.net/lxj434368832/article/details/78874108

https://www.cnblogs.com/aminxu/p/4704281.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/155062.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • MMC卡原理和操作分析「建议收藏」

    MMC卡原理和操作分析「建议收藏」MMC卡原理和操作分析 转载于:https://blog.51cto.com/laokaddk/1253993

  • centos7 安装nginx 完整步骤「建议收藏」

    centos7 安装nginx 完整步骤「建议收藏」1.安装gccgcc是用来编译下载下来的nginx源码 yuminstallgcc-c++2、安装pcre和pcre-devel  PCRE(PerlCompatibleRegularExpressions)是一个Perl库,包括perl兼容的正则表达式库。nginx的http模块使用pcre来解析正则表达式,pcre-devel是使用pcre开…

  • 【免费分享】让思路更清晰,思维导图教程及工具[通俗易懂]

    思维导图,让思路更清晰,结构更完整。当你大脑一片混乱不知道该从什么地方做起,可以试着使用一下思维导图工具。昨天列了一下这一年关于自己提升的一些方面,使用思维导图进行简单的列举,有一些好友希望知道我使用的是那个工具来画思维导图的。下面简单介绍一些思维导图工具,在日常生活和工作中希望能够帮助到你。XMind【离线】XMind是一个开源的脑图项目,可以自由下载使用。有XMind Plus…

  • 购买部署阿里免费ssl证书的步骤「建议收藏」

    购买部署阿里免费ssl证书的步骤「建议收藏」ssl证书购买页面购买后如下点击证书申请填写证书信息下一步需要验证信息添加域名解析记录,内容是上面的截图,需要到自己的域名添加签发成功后进行部署需要一台http服务器,这里以nginx为例子,阿里有关于部署的说明文档,上面已签发右边操作中有一个下载,如下选择下载后根据帮助,找到文档如nginx的文档关于部署https服务我前面一篇文章也有记录nginx部署https服务…

  • C语言输出各种三角形

    C语言输出各种三角形for(i=0;i&lt;n;i++){for(j=0;j&lt;=i;j++)printf("*");printf("\n");}printf("\n");for(i=0;i&lt;n;i++){for(j=0;j&lt;n-i-1;j++)…

  • 区分clientHeight、scrollHeight、offsetHeight

    区分clientHeight、scrollHeight、offsetHeight区分clientHeight、scrollHeight、offsetHeightclientHeight:元素的可见高度scrollHeight:元素的整体高度offsetHeight:元素的高度参考文献:[1]搞清clientHeight、offsetHeight、scrollHeight、offsetTop、scrollTop[2]js中offsetHe…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号