字符转换(C、C++)
标准C和C++库提供了一些转换工具。但是它们在易用性、扩展型和安全型上各有不同。
例如,以atoi为代表的一系列标准C函数就有一些限制:
* 只支持单向转换:从文本到内部数据类型。要用C库函数实现另一个方向的转换,要么使用不太方便并且有损安全性的sprintf,要么牺牲可移植性,使用非标准函数,例如itoa。
* 支持的类型只是内建数值类型的一个子集,即int、long和double。
* 支持的类型不能用统一的方式扩展。例如从字符串表示转为complex或者rational。
以strtol为代表的标准C函数也有同样的基本限制,但它们对转换过程提供了更好的控制。然而,通常情况下这样的控制既不需要也没人用。scanf系列函数甚至提供了更多的控制,但同样缺少安全性和易用性。
标准C++库为这种转换提供了stringstream。它提供了大量格式控制,并且可以通过以文本中介进行任意类型之间的转换。但是对于简单转换,直接用stringstream可能显得很笨拙(引入额外的局部变量,并失去了嵌在表达式里使用的方便性),或者很难懂(在表达式里创建stringstream的临时对象)。Facets为控制文本的表现形式提供了全面的概念和机制,但是它相对较高的门槛使简单转换也牵涉到太深的技术。
lexical_cast模板函数提供了方便而且统一的形式来进行任意类型(当它们可以表示为文本)之间的转换。因为你可以把这种转换方便地写在表达式内,所以它可以简化你的程序。对于更复杂的转换,例如需要对精度或者格式作一些比lexical_cast缺省行为更严格的控制时,那么还是建议你用常规的stringstream方法。如果是数值到数值的转换,numeric_cast的行为要比lexical_cast更合理些 #include<stdio.h>
#include<stdlib.h>
#include<string.h>
int tonum(char *string)
{
int n=,i;
if(*string=='-')
i=-;
else
i=;
while(!(*string>=''&&*string<=''))
string++;
while(*string>=''&&*string<='')
{
n*=;
n+=*string-'';
string++;
}
return n*i;
}
char * tostring(int n,char *p)
{
char *q;
char *str=(char*)malloc();
if(p==NULL)
return NULL;
if(n<)
{
strcpy(str,"-");
n=abs(n);
}
else
strcpy(str,"");
p[]=n/+'';
n=n%;
p[]=n/+'';
n=n%;
p[]=n/+'';
n=n%;
p[]=n/+'';
n=n%;
p[]=n+'';
p[]='\0';
q=p;
while(*q!='\0'&&*q=='')
q++;
if(*q=='\0')
return p;
strcpy(p,q);
if(!strcmp(str,"-"))
{
strcat(str,p);
strcpy(p,str);
}
free(str);
return p;
}
int main()
{
char *string=new char[];
strcpy(string,"-123");
printf("%d\n",tonum(string));
printf("--------------------------\n");
printf("%s",tostring(-,string));
getchar();
delete string;
return ;
} #include <windows.h>
#include <iostream>
using std::cout;
using std::cin;
using std::endl;
void int2str(int n,char * &p);
void str2int(const char *str,int& num);
int main()
{
//int to string
int num;
char* p=NULL;
cout<<"input a num:";
cin>>num;
int2str(num,p);
cout<<p<<endl;
//string to int
char arr[];
char *buf=arr;
cout<<"input a string that is num:";
cin>>buf;
int n=;
str2int(buf,n);
cout<<n;
system("pause");
return ;
}
void int2str(int n,char * &p)
{
int i=,len=;
char buf[];
memset(buf,,sizeof(buf)/sizeof(buf[]));
int temp=(n<?\
-n:n);
while(temp)
{
buf[i++]=temp%+'';
temp=temp/;
}
len=i;
if(n<)
{
p=(char *)malloc(len*sizeof(char)+);
p[]='-';
for(i=len-;i>=;i--)
{
p[len-i]=buf[i];
}
p[len+]='\0';
}
else
{
p=(char *)malloc(len*sizeof(char)+);
for(i=len-;i>=;i--)
{
p[len-i-]=buf[i];
}
p[len]='\0';
}
}
void str2int(const char *str,int& num)
{
const char *p=str;
int temp=;
if(*p>''||*p<'')
++p;
int len=strlen(p);
for(int i=;i<len;i++)
{
temp=temp*+(*p++ - '');
}
num=(*str=='-'?(-temp):temp);
} int atoi(const char *s)
{
char *p = s;
char c;
int i = ;
while(c=*p++)
{
if(c>='' && c <='')
{
i = i* + (c-'');
}
else
return -; //Invalid string
}
return i;
}
********************************************************************************************
itoa 把一整数转换为字符串
例程序:
#include <ctype.h>
#include <stdio.h>
void itoa (int n,char s[]);
//atoi 函数:将s转换为整形数
int main(void )
{
int n;
char s[];
printf("Input n:\n");
scanf("%d",&n);
printf("the string : \n");
itoa (n,s);
return ;
}
void itoa (int n,char s[])
{
int i,j,sign;
if((sign=n)<)//记录符号
n=-n;//使n成为正数
i=;
do{
s[i++]=n%+'';//取下一个数字
}while ((n/=)>);//删除该数字
if(sign<)
s[i++]='-';
s[i]='\0';
for(j=i;j>=;j--)//生成的数字是逆序的,所以要逆序输出
printf("%c",s[j]); } java 怎样把字符串数组如 String array[]={"","","","",""};
转化成int型的 ?
String array[] = { "", "", "", "", "" };
int[] number = new int[array.length];
for (int i = ; i < array.length; i++) {
int num = Integer.parseInt(array[i]);// 转换
number[i] = num;
}
System.out.println(number.length); # include <stdio.h>
# include <stdlib.h> int main ()
{
int num_int;
double num_double;
char str_int[] = ""; //将要被转换为整型的字符串
char str_double[] = "436.55"; //将要被转换为浮点型的字符串 num_int = atoi(str_int); //转换为整型值
num_double = atof(str_double); //转换为浮点型值 printf("num_int: %d\n", num_int);
printf("num_double: %lf\n", num_double); return ;
} #include <iostream> using namespace std; int str2int(const char *str) { int temp = ; const char *ptr = str; //ptr保存str字符串开头8 9 if (*str == '-' || *str == '+') //如果第一个字符是正负号,10 { //则移到下一个字符11 str++;12 }13 while(*str != 0)14 {15 if ((*str < '0') || (*str > '9')) //如果当前字符不是数字16 { //则退出循环17 break;18 }19 temp = temp * 10 + (*str - '0'); //如果当前字符是数字则计算数值20 str++; //移到下一个字符21 } 22 if (*ptr == '-') //如果字符串是以"-"开头,则转换成其相反数23 {24 temp = -temp;25 }26 27 return temp;28 }29 30 int main()31 {32 int n = 0; 33 char p[10] = "";34 35 cin.getline(p, 20); //从终端获取一个字符串36 n = str2int(p); //把字符串转换成整型数37 38 cout << n << endl;39 40 return 0;41 }
字符转换(C、C++)的更多相关文章
- 【JavaScript】JS 中 原始字符串 和 HTML 字符转换
参考资料:http://www.sjyhome.com/javascript/js-html-escape.html JS转换HTML转义符 SJY • 发表于:2013年10月05日 17:04 • ...
- 带毫秒的字符转换成时间(DateTime)格式的通用方法
C#自身有更好的方式,Net任意String格式转换为DateTime类型 ====================================================== 原文 ==== ...
- sql字符转换函数大全
删除空格 有两个函数,TTRIM()和LTRIM(),可以用来从字符串中剪掉空格.函数LTRIM()去除应该字符串前面的所有空格:函数RTRIM()去除一个字符串尾部的所有空格.这些和vbscript ...
- python_way,day3 集合、函数、三元运算、lambda、python的内置函数、字符转换、文件处理
python_way,day3 一.集合 二.函数 三.三元运算 四.lambda 五.python的内置函数 六.字符转换 七.文件处理 一.集合: 1.集合的特性: 特性:无序,不重复的序列 如果 ...
- js字符转换成整型 parseInt()函数规程Number()函数
今天在做一个js加法的时候,忘记将字符转换成整型,导致将加号认为是连接符, 在运算前要先对字符井行类型转换,使用parseInt()函数 使用Number()将字符转换成int型效果更好
- mysql将字符转换成数字
在操作mysql时,经常需要将字符转换成数字,这一步虽然简单,但不常用的话也很容易忘记,现将在网上找到的方法记录如下: 1.将字符的数字转成数字,比如'0'转成0可以直接用加法来实现例如:将pony表 ...
- CString string char* char 之间的字符转换(多种方法)
在写程序的时候,我们经常遇到各种各样的类型转换,比如 char* CString string 之间的互相转换.首先解释下三者的含义. CString 是一种很有用的数据类型.它们很大程度上简化了MF ...
- Linux c字符串中不可打印字符转换成16进制
本文由 www.169it.com 搜集整理 如果一个C字符串中同时包含可打印和不可打印的字符,如果想将这个字符串写入文件,同时方便打开文件查看或者在控制台中打印出来不会出现乱码,那么可以将字符串中的 ...
- vc++字符转换
测试环境: vs2008 开发语言:C++ #include <iostream>#include <windows.h>#include <string> // ...
- [c/c++] programming之路(6)、ASCII码,数据类型、随机数、字符转换及拼接等
一.变量 #include<stdio.h> #include<stdlib.h> void main0(){ //数据使用必须在范围内,否则产生溢出 unsigned +;/ ...
随机推荐
- FastJson和AsyncHttpCLient
Android的展示数据,除了上章所讲的本地存储外,大部分数据都来自于网络.首先介绍一下Android APP开发常见的网络操作方式.从网络层面上有底层的tcp/ip,也就是我们常见的socket套接 ...
- jcl-over-slf4j log桥接工具简介
ava 界里有许多实现日志功能的工具,最早得到广泛使用的是 log4j,许多应用程序的日志部分都交给了 log4j,不过作为组件开发者,他们希望自己的组件不要紧紧依赖某一个工具,毕竟在同一个时候还有很 ...
- 【30集iCore3_ADP出厂源代码(ARM部分)讲解视频】30-1 前言
视频简介: 该视频介绍收到iCore3应用开发平台后如何获取出厂代码,以 及如何下载出厂代码到应用开发平台中. 源视频包下载地址: http://pan.baidu.com/s/1nuUZW17 ...
- 利用jemalloc优化mysql
一.下载安装jemalloc #wget http://www.canonware.com/download/jemalloc/jemalloc-3.6.0.tar.bz2 #tar jxvf jem ...
- jquery的each()详细介绍
each()方法能使DOM循环结构简洁,不容易出错.each()函数封装了十分强大的遍历功能,使用也很方便,它可以遍历一维数组.多维数组.DOM, JSON 等等在javaScript开发过程中使用$ ...
- 微信支付开发(7) H5支付
关键字:微信支付 微信支付v3 H5支付 wap支付 prepay_id 作者:方倍工作室原文: http://www.cnblogs.com/txw1958/p/wxpayv3_h5.html 本文 ...
- windows下mysqlbinlog二进制恢复
Mysql数据恢复主要针对Windows游戏引擎服务器意外宕机,以及游戏出现重大BUG,导致需要回档. 注意:请在恢复数据库之前,备份目标数据库,切记! 一.Windows服务器意外DOWN机,数据库 ...
- 手机QQ内置网页,微信内置网页中进行分享到QQ和微信的操作
微信内的网页分享: API内容详见微信开发文档 https://mp.weixin.qq.com/wiki 这里需要注意的是:调用微信API的时候修改的是微信内网页右上角三个点那里打开后,选择分享之 ...
- css3的新特性transform,transition,animation
一.transform css3引入了一些可以对网页元素进行变换的属性,比如旋转,缩放,移动,或者沿着水平或者垂直方向扭曲(斜切变换)等等.这些的基础都是transform属性 transform属性 ...
- Git(分布式版本控制系统)在Windows下的使用-将代码托管到开源中国(oschina)
一.Git是什么? Git --- The stupid content tracker, 傻瓜内容跟踪器.Git是目前世界上最先进的分布式版本控制系统. 二.SVN与Git的最主要的区别? ...