百度
360搜索
搜狗搜索

strtod,C里面怎么把字符串转成数字详细介绍

本文目录一览: C语言中有没有把字符转型化为 浮点型的函数?

C语言中将字符串转型化为浮点型数据的函数有:atof()

strtod()
头文件:
#include

函数原型:

double atof (const char* str);

【参数说明】str 为要转换的字符串。

【函数说明】atof() 函数会扫描参数str字符串,跳过前面的空白字符(例如空格,tab缩进等,可以通过 isspace() 函数来检测),直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('\0')才结束转换,并将结果返回。参数str 字符串可包含正负号、小数点或E(e)来表示指数部分,如123. 456 或123e-2。

【返回值】返回转换后的浮点数;如果字符串 str 不能被转换为 double,那么返回 0.0。

double strtod (const char* str, char** endptr);

【参数说明】str 为要转换的字符串,endstr 为第一个不能转换的字符的指针。

【函数说明】strtod() 函数会扫描参数str字符串,跳过前面的空白字符(例如空格,tab缩进等,可以通过 isspace() 函数来检测),直到遇上数字或正负符号才开始做转换,到出现非数字或字符串结束时('\0')才结束转换,并将结果返回。参数 str 字符串可包含正负号、小数点或E(e)来表示指数部分。如123. 456 或123e-2。

若endptr 不为NULL,则会将遇到的不符合条件而终止的字符指针由 endptr 传回;若 endptr 为 NULL,则表示该参数无效,或不使用该参数。

【返回值】返回转换后的浮点型数;若不能转换或字符串为空,则返回 0.0。

使用 atof( str ) 与使用 strtod(str, NULL) 结果相同。

一般应用方法为:

char str[]="123.45";

double d=atof(str);

printf("%.2lf", d ); //输出123.45

c语言strtod()函数的用法

index对应第一个操作数的字符数,这个前提是操作数前面没有空格一类另strtod自动跳过的字符。
因为endptr是strtod转换字符串的结尾位置,比如buf中的字符串是1234abc,转换时将转换到1234为止,strtod发现字符a不属于合法数字内容,会在遇到a时结束转换,并另endptr指向a的这个位置。index=endptr-buf;会得到a字符前面有几个字符的计数。

C语言中字符串和整数小数相互转换的函数都有什么?

字符串转到数(stdlib.h头文件):atof(将字符串转换成浮点型数)atoi(将字符串转换成整型数)atol(将字符串转换成长整型数)strtod(将字符串转换成浮点数)strtol(将字符串转换成长整型数)strtoul(将字符串转换成无符号长整型数)
数转到字符串(stdio.h头文件):sprintf(格式输出,可以转换任何类型变量到字符串)
头文件 stdlib.h
字符串转换函数 函数列表
函数用途 函数名
字符串转换为整数 atoi
字符串转换为长整数 atol
字符串转换为浮点数 strtod
字符串转换为长整数 strtol
字符串转换为无符号长整型 strtoul
字符串转换函数如下:
字符串转换为整数 atoi
2.字符串转换为长整数 atol
3.字符串转换为浮点数 strtod
4.字符串转换为长整数 strtol
5.字符串转换为无符号长整型 strtoul
C语言是一门通用计算机编程语言,应用广泛。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。
尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译,甚至包含一些嵌入式处理器(单片机或称MCU)以及超级电脑等作业平台。

include(stdlib.h)什么意思?

#include

称为编译预处理命令。编译预处理命令还有很多,它们都以“#”开头,并且不用分号结尾,所以是c语言的程序语句。

在使用标准函数库中的输入输出函数时,编译系统要求程序提供有关的信息(例如对这些输入输出函数的声明),#include

的作用就是用来提供这些信息的,stdio是“standard input & output”的缩写,即有关标准输入输出的信息。

在头文件

中说明了用于数值转换、内存分配以及具有其他相似任务的函数。

1、atof

#include

double atof(const char*str);把字符串str转换成double类型。等价于:strtod(str,(char**)NUL1)。

2、atoi

#include

int atoi(const char*str);把字符串str转换成int类型。等价于:(int)strtol(str,(char**)NULL,10)。

3、atol

#include

long atol(const char*str):把字符串str转换成long类型。等价于:strtol(str,(char**)NULL,10)。

4、strtod

#inelude

double strtod(const char*start,char**end);

错误:提供给函数 ‘strtod’ 的实参太多

strtod()这个函数只有两个形式参数,你的代码行strtod(a,NULL,10)中提供了3个:a、NULL、10,前两个是匹配的,最后一个多出来了,干什么用?这个函数返回一个双精度十进制数,你的printf("a = %d\n",strtod(a,NULL,10))中的控制符%d也用得不匹配,要用%f或%lf。

求字符串处理函数(全)

1、字符串长度函数strlen(参数)
  解释:求出字符串中有效字符的个数,参数可以是指针、字符串、数组
  例如:char aa[]="abc";
  char *p=aa;
  strlen(aa)=strlen(p)=strlen("abc")
  2、字符串比较函数strcmp()和strncmp()
  解释:将两个字符串逐个进行比较,当遇到两个字符不同时便停止比较,用前面字符串中的字符与后面字符串中对应的字符进行相减,得到一个大于或小于0的字符,若返回值
  为0,则字符串相等。strncmp()只比交前n个字符
  格式:strcmp(char *p1,char *p2) strncmp(char *p1,char*p2,n)
  p1 p2可以是指针 也可以是字符数组
  3、检索字符串函数index()或rindex
  解释:该函数的功能是检索在指定的字符串中第一次出现指定字符的位置,该函数返回一个指针,该指针给出指定字符在字符串中的位置,若该字符串中没有该字符则返回NULL 格式:char*index(char *p,charc) char *rindex(char *p,char c) index 从作向右 rindex 从右向左
  4、字符串连接函数strcat()和 strncat()
  解释:连接两个字符串,将第二个字符串连接到第一个字符串的后面,组成一个新的字符串,并返回一个指针,该指针指向新字符串的首元素
  格式:char *strcat(char s1[],char s2[]), char *strncat(chars1[],char s2[],n)
  该函数的参数可以是指针 也可以是数组
  5、字符串复制函数strcpy()和strncpy()
  解释:将后面的字符串复制到前面的字符串中,后面字符串保持不变,前面的字符串被覆盖掉,并返回一个指针
  格式:char * strcpy(char s1[],char s2[]) char*strncpy(char s1[],char s2[],n);
  参数可以是字符数组或者指针
AddSlashes: 字符串加入斜线。
bin2hex: 二进位转成十六进位。
Chop: 去除连续空白。
Chr: 返回序数值的字符。
chunk_split: 将字符串分成小段。
convert_cyr_string: 转换古斯拉夫字符串成其它字符串。
crypt: 将字符串用 DES 编码加密。
echo: 输出字符串。
explode: 切开字符串。
flush: 清出输出缓冲区。
get_meta_tags: 抽出文件所有 meta 标记的资料。
htmlspecialchars: 将特殊字符转成 HTML 格式。
htmlentities: 将所有的字符都转成 HTML 字符串。
implode: 将数组变成字符串。
join: 将数组变成字符串。
ltrim: 去除连续空白。
md5: 计算字符串的 MD5 哈稀。
nl2br: 将换行字符转成

Ord: 返回字符的序数值。
parse_str: 解析 query 字符串成变量。
print: 输出字符串。
printf: 输出格式化字符串。
quoted_printable_decode: 将 qp 编码字符串转成 8 位字符串。
QuoteMeta: 加入引用符号。
rawurldecode: 从 URL 专用格式字符串还原成普通字符串。
rawurlencode: 将字符串编码成 URL 专用格式。
setlocale: 配置地域化信息。
similar_text: 计算字符串相似度。
soundex: 计算字符串的读音值
sprintf: 将字符串格式化。
strchr: 寻找第一个出现的字符。
strcmp: 字符串比较。
strcspn: 不同字符串的长度。
strip_tags: 去掉 HTML 及 PHP 的标记。
StripSlashes: 去掉反斜线字符。
strlen: 取得字符串长度。
strrpos: 寻找字符串中某字符最后出现处。
strpos: 寻找字符串中某字符最先出现处。
strrchr: 取得某字符最后出现处起的字符串。
strrev: 颠倒字符串。
strspn: 找出某字符串落在另一字符串遮罩的数目。
strstr: 返回字符串中某字符串开始处至结束的字符串。
strtok: 切开字符串。
strtolower: 字符串全转为小写。
strtoupper: 字符串全转为大写。
str_replace: 字符串取代。
strtr: 转换某些字符。
substr: 取部份字符串。
trim: 截去字符串首尾的空格。
ucfirst: 将字符串第一个字符改大写。
ucwords: 将字符串每个字第一个字母改大写。
parse_url: 解析 URL 字符串。
urldecode: 还原 URL 编码字符串。
urlencode: 将字符串以 URL 编码。
base64_encode: 将字符串以 BASE64 编码。
base64_decode: 将 BASE64 编码字符串解码。
函数名: stpcpy
功 能: 拷贝一个字符串到另一个
用 法: char *stpcpy(char *destin, char *source);
程序例:
#include

#include

int main(void)

{

char string[10];

char *str1 = "abcdefghi";

stpcpy(string, str1);

printf("%sn", string);

return 0;

}

函数名: strcat

功 能: 字符串拼接函数

用 法: char *strcat(char *destin, char *source);

程序例:

#include

#include

int main(void)

{

char destination[25];

char *blank = " ", *c = "C++", *Borland = "Borland";

strcpy(destination, Borland);

strcat(destination, blank);

strcat(destination, c);

printf("%sn", destination);

return 0;

}

函数名: strchr

功 能: 在一个串中查找给定字符的第一个匹配之处

用 法: char *strchr(char *str, char c);

程序例:

#include

#include

int main(void)

{

char string[15];

char *ptr, c = 'r';

strcpy(string, "This is a string");

ptr = strchr(string, c);

if (ptr)

printf("The character %c is at position: %dn", c, ptr-string);

else

printf("The character was not foundn");

return 0;

}

函数名: strcmp

功 能: 串比较

用 法: int strcmp(char *str1, char *str2);

看Asic码,str1>str2,返回值 > 0;两串相等,返回0

程序例:

#include

#include

int main(void)

{

char *buf1 = "aaa", *buf2 = "bbb", *buf3 = "ccc";

int ptr;

ptr = strcmp(buf2, buf1);

if (ptr > 0)

printf("buffer 2 is greater than buffer 1n");

else

printf("buffer 2 is less than buffer 1n");

ptr = strcmp(buf2, buf3);

if (ptr > 0)

printf("buffer 2 is greater than buffer 3n");

else

printf("buffer 2 is less than buffer 3n");

return 0;

}

函数名: strncmpi

功 能: 将一个串中的一部分与另一个串比较, 不管大小写

用 法: int strncmpi(char *str1, char *str2, unsigned maxlen);

程序例:

#include

#include

int main(void)

{

char *buf1 = "BBB", *buf2 = "bbb";

int ptr;

ptr = strcmpi(buf2, buf1);

if (ptr > 0)

printf("buffer 2 is greater than buffer 1n");

if (ptr < 0)

printf("buffer 2 is less than buffer 1n");

if (ptr == 0)

printf("buffer 2 equals buffer 1n");

return 0;

}

函数名: strcpy

功 能: 串拷贝

用 法: char *strcpy(char *str1, char *str2);

程序例:

#include

#include

int main(void)

{

char string[10];

char *str1 = "abcdefghi";

strcpy(string, str1);

printf("%sn", string);

return 0;

}

函数名: strcspn

功 能: 在串中查找第一个给定字符集内容的段

用 法: int strcspn(char *str1, char *str2);

程序例:

#include

#include

#include

int main(void)

{

char *string1 = "1234567890";

char *string2 = "747DC8";

int length;

length = strcspn(string1, string2);

printf("Character where strings intersect is at position %dn", length);

return 0;

}

函数名: strdup

功 能: 将串拷贝到新建的位置处

用 法: char *strdup(char *str);

程序例:

#include

#include

#include

int main(void)

{

char *dup_str, *string = "abcde";

dup_str = strdup(string);

printf("%sn", dup_str);

free(dup_str);

return 0;

}

函数名: stricmp

功 能: 以大小写不敏感方式比较两个串

用 法: int stricmp(char *str1, char *str2);

程序例:

#include

#include

int main(void)

{

char *buf1 = "BBB", *buf2 = "bbb";

int ptr;

ptr = stricmp(buf2, buf1);

if (ptr > 0)

printf("buffer 2 is greater than buffer 1n");

if (ptr < 0)

printf("buffer 2 is less than buffer 1n");

if (ptr == 0)

printf("buffer 2 equals buffer 1n");

return 0;

}

函数名: strerror

功 能: 返回指向错误信息字符串的指针

用 法: char *strerror(int errnum);

程序例:

#include

#include

int main(void)

{

char *buffer;

buffer = strerror(errno);

printf("Error: %sn", buffer);

return 0;

}

函数名: strcmpi

功 能: 将一个串与另一个比较, 不管大小写

用 法: int strcmpi(char *str1, char *str2);

程序例:

#include

#include

int main(void)

{

char *buf1 = "BBB", *buf2 = "bbb";

int ptr;

ptr = strcmpi(buf2, buf1);

if (ptr > 0)

printf("buffer 2 is greater than buffer 1n");

if (ptr < 0)

printf("buffer 2 is less than buffer 1n");

if (ptr == 0)

printf("buffer 2 equals buffer 1n");

return 0;

}

函数名: strncmp

功 能: 串比较

用 法: int strncmp(char *str1, char *str2, int maxlen);

程序例:

#include

#include

int main(void)

{

char *buf1 = "aaabbb", *buf2 = "bbbccc", *buf3 = "ccc";

int ptr;

ptr = strncmp(buf2,buf1,3);

if (ptr > 0)

printf("buffer 2 is greater than buffer 1n");

else

printf("buffer 2 is less than buffer 1n");

ptr = strncmp(buf2,buf3,3);

if (ptr > 0)

printf("buffer 2 is greater than buffer 3n");

else

printf("buffer 2 is less than buffer 3n");

return(0);

}

函数名: strncmpi

功 能: 把串中的一部分与另一串中的一部分比较, 不管大小写

用 法: int strncmpi(char *str1, char *str2);

程序例:

#include

#include

int main(void)

{

char *buf1 = "BBBccc", *buf2 = "bbbccc";

int ptr;

ptr = strncmpi(buf2,buf1,3);

if (ptr > 0)

printf("buffer 2 is greater than buffer 1n");

if (ptr < 0)

printf("buffer 2 is less than buffer 1n");

if (ptr == 0)

printf("buffer 2 equals buffer 1n");

return 0;

}

阅读更多 >>>  复合函数求导,求复合函数求导公式

函数名: strncpy

功 能: 串拷贝

用 法: char *strncpy(char *destin, char *source, int maxlen);

程序例:

#include

#include

int main(void)

{

char string[10];

char *str1 = "abcdefghi";

strncpy(string, str1, 3);

string[3] = '';

printf("%sn", string);

return 0;

}

函数名: strnicmp

功 能: 不注重大小写地比较两个串

用 法: int strnicmp(char *str1, char *str2, unsigned maxlen);

程序例:

#include

#include

int main(void)

{

char *buf1 = "BBBccc", *buf2 = "bbbccc";

int ptr;

ptr = strnicmp(buf2, buf1, 3);

if (ptr > 0)

printf("buffer 2 is greater than buffer 1n");

if (ptr < 0)

printf("buffer 2 is less than buffer 1n");

if (ptr == 0)

printf("buffer 2 equals buffer 1n");

return 0;

}

函数名: strnset

功 能: 将一个串中的所有字符都设为指定字符

用 法: char *strnset(char *str, char ch, unsigned n);

程序例:

#include

#include

int main(void)

{

char *string = "abcdefghijklmnopqrstuvwxyz";

char letter = 'x';

printf("string before strnset: %sn", string);

strnset(string, letter, 13);

printf("string after strnset: %sn", string);

return 0;

}

函数名: strpbrk

功 能: 在串中查找给定字符集中的字符

用 法: char *strpbrk(char *str1, char *str2);

程序例:

#include

#include

int main(void)

{

char *string1 = "abcdefghijklmnopqrstuvwxyz";

char *string2 = "onm";

char *ptr;

ptr = strpbrk(string1, string2);

if (ptr)

printf("strpbrk found first character: %cn", *ptr);

else

printf("strpbrk didn't find character in setn");

return 0;

}

函数名: strrchr

功 能: 在串中查找指定字符的最后一个出现

用 法: char *strrchr(char *str, char c);

程序例:

#include

#include

int main(void)

{

char string[15];

char *ptr, c = 'r';

strcpy(string, "This is a string");

ptr = strrchr(string, c);

if (ptr)

printf("The character %c is at position: %dn", c, ptr-string);

else

printf("The character was not foundn");

return 0;

}

函数名: strrev

功 能: 串倒转

用 法: char *strrev(char *str);

程序例:

#include

#include

int main(void)

{

char *forward = "string";

printf("Before strrev(): %sn", forward);

strrev(forward);

printf("After strrev(): %sn", forward);

return 0;

}

函数名: strset

功 能: 将一个串中的所有字符都设为指定字符

用 法: char *strset(char *str, char c);

程序例:

#include

#include

int main(void)

{

char string[10] = "123456789";

char symbol = 'c';

printf("Before strset(): %sn", string);

strset(string, symbol);

printf("After strset(): %sn", string);

return 0;

}

函数名: strspn

功 能: 在串中查找指定字符集的子集的第一次出现

用 法: int strspn(char *str1, char *str2);

程序例:

#include

#include

#include

int main(void)

{

char *string1 = "1234567890";

char *string2 = "123DC8";

int length;

length = strspn(string1, string2);

printf("Character where strings differ is at position %dn", length);

return 0;

}

函数名: strstr

功 能: 在串中查找指定字符串的第一次出现

用 法: char *strstr(char *str1, char *str2);

程序例:

#include

#include

int main(void)

{

char *str1 = "Borland International", *str2 = "nation", *ptr;

ptr = strstr(str1, str2);

printf("The substring is: %sn", ptr);

return 0;

}

函数名: strtod

功 能: 将字符串转换为double型值

用 法: double strtod(char *str, char **endptr);

程序例:

#include

#include

int main(void)

{

char input[80], *endptr;

double value;

printf("Enter a floating point number:");

gets(input);

value = strtod(input, &endptr);

printf("The string is %s the number is %lfn", input, value);

return 0;

}

函数名: strtok

功 能: 查找由在第二个串中指定的分界符分隔开的单词

用 法: char *strtok(char *str1, char *str2);

程序例:

#include

#include

int main(void)

{

char input[16] = "abc,d";

char *p;

/* strtok places a NULL terminator

in front of the token, if found */

p = strtok(input, ",");

if (p) printf("%sn", p);

/* A second call to strtok using a NULL

as the first parameter returns a pointer

to the character following the token */

p = strtok(NULL, ",");

if (p) printf("%sn", p);

return 0;

}

函数名: strtol

功 能: 将串转换为长整数

用 法: long strtol(char *str, char **endptr, int base);

程序例:

#include

#include

int main(void)

{

char *string = "87654321", *endptr;

long lnumber;

/* strtol converts string to long integer */

lnumber = strtol(string, &endptr, 10);

printf("string = %s long = %ldn", string, lnumber);

return 0;

}

函数名: strupr

功 能: 将串中的小写字母转换为大写字母

用 法: char *strupr(char *str);

程序例:

#include

#include

int main(void)

{

char *string = "abcdefghijklmnopqrstuvwxyz", *ptr;

/* converts string to upper case characters */

ptr = strupr(string);

printf("%sn", ptr);

return 0;

}

函数名: swab

功 能: 交换字节

用 法: void swab (char *from, char *to, int nbytes);

程序例:

#include

#include

#include

char source[15] = "rFna koBlrna d";

char target[15];

int main(void)

{

swab(source, target, strlen(source));

printf("This is target: %sn", target);

return 0;

}

PS:isalpha()是字符函数,不是字符串函数,

isalpha

原型:extern int isalpha(int c);

用法:#include

功能:判断字符c是否为英文字母

说明:当c为英文字母a-z或A-Z时,返回非零值,否则返回零。

举例:

// isalpha.c

#include

#include

#include

main()

{

int c;

clrscr(); // clear screen

printf("Press a key");

for(;;)

{

c=getchar();

clrscr();

printf("%c: %s letter",c,isalpha(c)?"is":"not");

}

return 0; // just to avoid warnings by compiler

}

C语言字符串

trcpy(p, p1) 复制字符串
strncpy(p, p1, n) 复制指定长度字符串
strcat(p, p1) 附加字符串
strncat(p, p1, n) 附加指定长度字符串
strlen(p) 取字符串长度
strcmp(p, p1) 比较字符串
strcasecmp忽略大小写比较字符串
strncmp(p, p1, n) 比较指定长度字符串
strchr(p, c) 在字符串中查找指定字符
strrchr(p, c) 在字符串中反向查找
strstr(p, p1) 查找字符串
strpbrk(p, p1) 以目标字符串的所有字符作为集合,在当前字符串查找该集合的任一元素
strspn(p, p1) 以目标字符串的所有字符作为集合,在当前字符串查找不属于该集合的任一元素的偏移
strcspn(p, p1) 以目标字符串的所有字符作为集合,在当前字符串查找属于该集合的任一元素的偏移
* 具有指定长度的字符串处理函数在已处理的字符串之后填补零结尾符
2)字符串到数值类型的转换
strtod(p, ppend) 从字符串 p 中转换 double 类型数值,并将后续的字符串指针存储到 ppend 指向的 char* 类型存储。
strtol(p, ppend, base) 从字符串 p 中转换 long 类型整型数值,base 显式设置转换的整型进制,设置为 0 以根据特定格式判断所用进制,0x, 0X 前缀以解释为十六进制格式整型,0 前缀以解释为八进制格式整型
atoi(p) 字符串转换到 int 整型
atof(p) 字符串转换到 double 符点数
atol(p) 字符串转换到 long 整型
3)字符检查
isalpha() 检查是否为字母字符
isupper() 检查是否为大写字母字符
islower() 检查是否为小写字母字符
isdigit() 检查是否为数字
isxdigit() 检查是否为十六进制数字表示的有效字符
isspace() 检查是否为空格类型字符
iscntrl() 检查是否为控制字符
ispunct() 检查是否为标点符号
isalnum() 检查是否为字母和数字
isprint() 检查是否是可打印字符
isgraph() 检查是否是图形字符,等效于 isalnum() | ispunct()
4)函数原型
原型:strcpy(char destination[], const char source[]);
功能:将字符串source拷贝到字符串destination中
例程:
#include

#include

void main(void)

{

  char str1[10] = { "TsinghuaOK"};

  char str2[10] = { "Computer"};

  cout <
<strcpy(str1,str2)<<endl;
}

运行结果是:Computer

第二个字符串将覆盖掉第一个字符串的所有内容!

注意:在定义数组时,字符数组1的字符串长度必须大于或等于字符串2的字符串长度。不能用赋值语句将一个字符串常量或字符数组直接赋给一个字符数组。所有字符串处理函数都包含在头文件string.h中。

strncpy(char destination[], const char source[], int numchars);

strncpy:将字符串source中前numchars个字符拷贝到字符串destination中。

strncpy函数应用举例

原型:strncpy(char destination[], const char source[], int numchars);

功能:将字符串source中前numchars个字符拷贝到字符串destination中

例程:

#include

#include

void main(void)

{

  char str1[10] = { "Tsinghua "};

  char str2[10] = { "Computer"};

  cout <
<strncpy(str1,str2,3)<<endl;
}

运行结果:Comnghua

注意:字符串source中前numchars个字符将覆盖掉字符串destination中前numchars个字符!

原型:strcat(char target[], const char source[]);

功能:将字符串source接到字符串target的后面

例程:

#include

#include

void main(void)

{

  char str1[] = { "Tsinghua "};

  char str2[] = { "Computer"};

  cout <
<strcpy(str1,str2)<<endl;
}

运行结果:Tsinghua Computer

注意:在定义字符数组1的长度时应该考虑字符数组2的长度,因为连接后新字符串的长度为两个字符串长度之和。进行字符串连接后,字符串1的结尾符将自动被去掉,在结尾串末尾保留新字符串后面一个结尾符。

原型:strncat(char target[], const char source[], int numchars);

功能:将字符串source的前numchars个字符接到字符串target的后面

例程:

#include

#include

void main(void)

{

  char str1[] = { "Tsinghua "};

  char str2[] = { "Computer"};

  cout <
<strncat(str1,str2,3)<<endl;
}

运行结果:Tsinghua Com

原型:int strcmp(const char firststring[], const char secondstring);

功能:比较两个字符串firststring和secondstring

例程:

#include

#include

void main(void)

{

  char buf1[] = "aaa";

  char buf2[] = "bbb";

  char buf3[] = "ccc";

  int ptr;

  ptr = strcmp(buf2,buf1);

  if(ptr > 0)

   cout <<"Buffer 2 is greater than buffer 1"<
<endl;
  else

   cout <<"Buffer 2 is less than buffer 1"<
<endl;
  ptr = strcmp(buf2,buf3);

  if(ptr > 0)

   cout <<"Buffer 2 is greater than buffer 3"<
<endl;
  else

   cout <<"Buffer 2 is less than buffer 3"<
<endl;
}

运行结果是:Buffer 2 is less than buffer 1

Buffer 2 is greater than buffer 3

原型:strlen( const char string[] );

功能:统计字符串string中字符的个数

例程:

#include

阅读更多 >>>  mysql字符串转数字,mysql如何将字符串转成数组?

#include

void main(void)

{

char str[100];

cout <<"请输入一个字符串:";

cin >>str;

cout <<"The length of the string is :"<
<strlen(str)<<"个"<<endl;
}

运行结果The length of the string is x (x为你输入的字符总数字)

注意:strlen函数的功能是计算字符串的实际长度,不包括'\0'在内。另外,strlen函数也可以直接测试字符串常量的长度,如:strlen("Welcome")。

void *memset(void *dest, int c, size_t count);

将dest前面count个字符置为字符c. 返回dest的值.

void *memmove(void *dest, const void *src, size_t count);

从src复制count字节的字符到dest. 如果src和dest出现重叠, 函数会自动处理. 返回dest的值.

void *memcpy(void *dest, const void *src, size_t count);

从src复制count字节的字符到dest. 与memmove功能一样, 只是不能处理src和dest出现重叠. 返回dest的值.

void *memchr(const void *buf, int c, size_t count);

在buf前面count字节中查找首次出现字符c的位置. 找到了字符c或者已经搜寻了count个字节, 查找即停止. 操作成功则返回buf中首次出现c的位置指针, 否则返回NULL.

void *_memccpy(void *dest, const void *src, int c, size_t count);

从src复制0个或多个字节的字符到dest. 当字符c被复制或者count个字符被复制时, 复制停止.

如果字符c被复制, 函数返回这个字符后面紧挨一个字符位置的指针. 否则返回NULL.

int memcmp(const void *buf1, const void *buf2, size_t count);

比较buf1和buf2前面count个字节大小.

返回值< 0, 表示buf1小于buf2;

返回值为0, 表示buf1等于buf2;

返回值> 0, 表示buf1大于buf2.

int memicmp(const void *buf1, const void *buf2, size_t count);

比较buf1和buf2前面count个字节. 与memcmp不同的是, 它不区分大小写.

返回值同上.

char *strrev(char *string);

将字符串string中的字符顺序颠倒过来. NULL结束符位置不变. 返回调整后的字符串的指针.

char *_strupr(char *string);

将string中所有小写字母替换成相应的大写字母, 其它字符保持不变. 返回调整后的字符串的指针.

char *_strlwr(char *string);

将string中所有大写字母替换成相应的小写字母, 其它字符保持不变. 返回调整后的字符串的指针.

char *strchr(const char *string, int c);

查找字 串string中首次出现的位置, NULL结束符也包含在查找中. 返回一个指针, 指向字符c在字符串string中首次出现的位置, 如果没有找到, 则返回NULL.

char *strrchr(const char *string, int c);

查找字符c在字符串string中最后一次出现的位置, 也就是对string进行反序搜索, 包含NULL结束符.

返回一个指针, 指向字符c在字符串string中最后一次出现的位置, 如果没有找到, 则返回NULL.

char *strstr(const char *string, const char *strSearch);

在字符串string中查找strSearch子串. 返回子串strSearch在string中首次出现位置的指针. 如果没有找到子串strSearch, 则返回NULL. 如果子串strSearch为空串, 函数返回string值.

char *strdup(const char *strSource);

函数运行中会自己调用malloc函数为复制strSource字符串分配存储空间, 然后再将strSource复制到分配到的空间中. 注意要及时释放这个分配的空间.

返回一个指针, 指向为复制字符串分配的空间; 如果分配空间失败, 则返回NULL值.

char *strcat(char *strDestination, const char *strSource);

将源串strSource添加到目标串strDestination后面, 并在得到的新串后面加上NULL结束符. 源串strSource的字符会覆盖目标串strDestination后面的结束符NULL. 在字符串的复制或添加过程中没有溢出检查, 所以要保证目标串空间足够大. 不能处理源串与目标串重叠的情况. 函数返回strDestination值.

char *strncat(char *strDestination, const char *strSource, size_t count);

将源串strSource开始的count个字符添加到目标串strDest后. 源串strSource的字符会覆盖目标串strDestination后面的结束符NULL. 如果count大于源串长度, 则会用源串的长度值替换count值. 得到的新串后面会自动加上NULL结束符. 与strcat函数一样, 本函数不能处理源串与目标串重叠的情况. 函数返回strDestination值.

char *strcpy(char *strDestination, const char *strSource);

复制源串strSource到目标串strDestination所指定的位置, 包含NULL结束符. 不能处理源串与目标串重叠的情况.函数返回strDestination值.

char *strncpy(char *strDestination, const char *strSource, size_t count);

将源串strSource开始的count个字符复制到目标串strDestination所指定的位置. 如果count值小于或等于strSource串的长度, 不会自动添加NULL结束符目标串中, 而count大于strSource串的长度时, 则将strSource用NULL结束符填充补齐count个字符, 复制到目标串中. 不能处理源串与目标串重叠的情况.函数返回strDestination值.

char *strset(char *string, int c);

将string串的所有字符设置为字符c, 遇到NULL结束符停止. 函数返回内容调整后的string指针.

char *strnset(char *string, int c, size_t count);

将string串开始count个字符设置为字符c, 如果count值大于string串的长度, 将用string的长度替换count值. 函数返回内容调整后的string指针.

size_t strspn(const char *string, const char *strCharSet);

查找任何一个不包含在strCharSet串中的字符 (字符串结束符NULL除外) 在string串中首次出现的位置序号. 返回一个整数值, 指定在string中全部由characters中的字符组成的子串的长度. 如果string以一个不包含在strCharSet中的字符开头, 函数将返回0值.

size_t strcspn(const char *string, const char *strCharSet);

查找strCharSet串中任何一个字符在string串中首次出现的位置序号, 包含字符串结束符NULL.

返回一个整数值, 指定在string中全部由非characters中的字符组成的子串的长度. 如果string以一个包含在strCharSet中的字符开头, 函数将返回0值.

char *strspnp(const char *string, const char *strCharSet);

查找任何一个不包含在strCharSet串中的字符 (字符串结束符NULL除外) 在string串中首次出现的位置指针. 返回一个指针, 指向非strCharSet中的字符在string中首次出现的位置.

char *strpbrk(const char *string, const char *strCharSet);

查找strCharSet串中任何一个字符在string串中首次出现的位置, 不包含字符串结束符NULL.

返回一个指针, 指向strCharSet中任一字符在string中首次出现的位置. 如果两个字符串参数不含相同字符, 则返回NULL值.

int strcmp(const char *string1, const char *string2);

比较字符串string1和string2大小.

返回值< 0, 表示string1小于string2;

返回值为0, 表示string1等于string2;

返回值> 0, 表示string1大于string2.

int stricmp(const char *string1, const char *string2);

比较字符串string1和string2大小,和strcmp不同, 比较的是它们的小写字母版本.返回值与strcmp相同.

int strcmpi(const char *string1, const char *string2);

等价于stricmp函数, 只是提供一个向后兼容的版本.

int strncmp(const char *string1, const char *string2, size_t count);

比较字符串string1和string2大小,只比较前面count个字符. 比较过程中, 任何一个字符串的长度小于count, 则count将被较短的字符串的长度取代. 此时如果两串前面的字符都相等, 则较短的串要小.

返回值< 0, 表示string1的子串小于string2的子串;

返回值为0, 表示string1的子串等于string2的子串;

返回值> 0, 表示string1的子串大于string2的子串.

int strnicmp(const char *string1, const char *string2, size_t count);

比较字符串string1和string2大小,只比较前面count个字符. 与strncmp不同的是, 比较的是它们的小写字母版本. 返回值与strncmp相同.

char *strtok(char *strToken, const char *strDelimit);

在strToken 串中查找下一个标记, strDelimit字符集则指定了在当前查找调用中可能遇到的分界符. 返回一个指针, 指向在strToken中找到的下一个标记. 如果找不到标记, 就返回NULL值. 每次调用都会修改strToken内容, 用NULL字符替换遇到的每个分界符.

c++概念字符串操作

一、char_traits 字符特征类

1)意义:包装特定串元素的通用行为界面,以便容器实现时依据特征信息而执行特定行为

2)定义了通用类型名

typedef _Elem char_type;

typedef int int_type;

typedef streampos pos_type;

typedef streamoff off_type;

typedef mbstate_t state_type;

其中 int_type 表示字符元素转换到特定编码时的整型表示,pos_type, off_type 分别作为字符串索引和字符串元素偏移的类型,类似容器迭中的指针,迭代类型和指针,迭代器的偏移类型。最后的 state_type 用于存储流状态,如出错,格式控制等等。

3)定义了字符 / 字符串操作的包装界面,以便通用算法的调用

assign(a, b) 定义将 b 字符赋值给 a 字符的过程,实现 a.operator = 的行为

eq(a, b) 定义 a 字符和 b 字符的相等关系,实现 a.operator == 的行为

lt(a, b) 定义 a 小于 b 的关系,实现 a.operator < 的行为

compare(a_ptr, b_ptr, cnt) 定义两组字符串的比较,返回 int 类型,实现类似 memcmp 的行为

length(ptr) 定义取字符串长度,实现类似 strlen 的行为

copy(a_ptr, b_ptr, cnt) 定义两组字符串的复制,实现类似 memcpy 的行为

move(a_ptr, b_ptr, cnt) 定义两组字符串的不重叠复制,实现类似 memmove 的行为

assign(ptr, cnt, ch) 定义了填充字符串的过程,实现类似 memset 的行为

to_int_type(ch) 定义了 char_type 到 int_type 整型的转换过程

to_char_type(n) 定义了 int_type 到 char_type 字符型的转换过程

eq_int_type(a, b) 定义两个和当前 char_type 类型对应的 int_type 的相等关系

eof() 定义字符串结尾符,使用整型表示

not_eof(n) 定义非字符串结尾符,若输入结尾符,则返回 1,其他输入返回原值,即总是不返回 eof()

4)int_type 类型应是当前字符类型的整型编码

二、std::string 并不是序列容器,没有 front() 和 back() 界面用于取出前端和尾端的元素,使用 std::string::operator [] 并传递 streampos 类型取得特定元素,如 std::string::size() - 1 作为索引取得最后一个字符

三、basic_string 支持的初始化

1)默认初始化

2)分配器

3)复制构造

4)局部复制 [_Roff, _Roff + _Count)

5)局部复制 + 分配器

6)C 字符串 [_Ptr,

)

7)C 字符串 + _Count [_Ptr, _Ptr + _Count)

8)C 字符串 + 分配器

9)C 字符串 + _Count + 分配器 [_Ptr, _Ptr + _Count)

10)_Count * _Ch

11)_Count * _Ch + 分配器

12)迭代器 [_ItF, _ItL)

13)迭代器 + 分配器

字符到串不能初始化,但支持 operator = 赋值和 operator += 累加赋值运算。

四、字符串的区间有效性

对串的索引访问在超过字符串的有效区间时,因为串的在实现上对内置的字符缓冲区执行下标访问,所以不会导致异常,但是将得到不可预知的结果,通常是不可用的。

将其他字符串作为右值输入时,对该串取出计数大于串大小时按串大小计算。

std::basic_string::size_type 的实际类型为 size_t,在 Visual C++ 7.1 中实现为 unsigned,std::basic_string::npos 被静态设定为

(basic_string<_Elem, _Traits, _Alloc>::size_type)(-1);

在查找子字符串等操作时,函数返回 npos 的值表示非法索引。

五、比较字符串

允许的比较对象

1)compare(s2) 其他同类型字符串

2)compare(p) C 风格字符串

3)compare(off, cnt, s2) [off, off + cnt) 同 s2 执行比较

4)compare(off, cnt, s2, off2, cnt2) [off, off + cnt) 同 s2 [off2, cnt2) 执行比较

5)compare(off, cnt, p) [off, off + cnt) 同 [p ,

) 执行比较

6)compare(off, cnt, p, cnt2) [off, off + cnt) 同 [p, p + cnt2) 执行比较

返回 -1, 0, 1 作为小于、等于和大于的比较结果。

六、附加数据

1)使用 operator += 接受其他字符串,C 风格字符串和字符

2)使用 push_back() 在尾部附加字符,并使得通过字符串构造的 back_iterator 可以访问

3)append() 附加

1、append(s) 追加字符串

2、append(s, off, cnt) 追加字符串 s [off, off + cnt)

3、append(p) 追加字符串 [p,

)

4、append(p, cnt) 追加字符串 [p, p + cnt)

5、append(n, c) 填充 n * c

6、append(InF, InL) 追加输入流 [InF, InL)

4)insert() 插入

1、insert(off, s2) 插入字符串

2、insert(off, s2, off2, cnt2) 插入字符串 s [off2, off2 + cnt2)

3、insert(off, p) 插入字符串 [p,

)

4、insert(off, p, cnt) 插入字符串 [p, p + cnt)

5、insert(off, n, c) 插入 n * c

6、insert(iter) 元素默认值填充

7、insert(iter, c) 插入特定元素

8、insert(iter, n, c) 插入 n*c

9、insert(iter, InF, InL) 插入 [InF, InL)

5)operator +(a, b)

字符串关联运算符重载中支持 operator + 的形式

1、s + s

2、s + p

3、s + c

4、p + s

5、c + s

七、查找、替换和清除

1)find() 查找

1、find(c, off) 在 s [off, npos) 中查找 c

2、find(p, off, n) 在 s [off, npos) 中查找 [p, p + n)

3、find(p, off) 在 s [off, npos) 中查找 [p,

)

4、find(s2, off) 在 s [off, npos) 中查找 s2

2)find() 的变种

1、rfind() 具有 find() 的输入形式,反序查找

2、find_first_of() 具有 find() 的输入形式,返回第一个匹配的索引

3、find_last_of() 具有 find() 的输入形式,返回倒数第一个匹配的索引

4、find_first_not_of() 具有 find() 的输入形式,返回第一个不匹配的索引

5、find_last_not_of() 具有 find() 的输入形式,返回倒数第一个不匹配的索引

3)replace() 替换

1、replace(off, cnt, s2) 将 s [off, off + cnt) 替换成 s2

2、replace(off, cnt, s2, off2, cnt2) 将 s [off, off + cnt) 替换成 s2 [off2, off2 + cnt2)

3、replace(off, cnt, p) 将 s [off, off + cnt) 替换成 [p,

)

4、replace(off, cnt, p, cnt2) 将 s [off, off + cnt) 替换成 [p, p + cnt2)

5、replace(off, cnt, n, c) 将 s [off, off + cnt) 替换成 c * n

使用迭代器的情况:

6、replace(InF, InL, s2) 将 [InF, InL) 替换成 s2

7、replace(InF, InL, p) 将 [InF, InL) 替换成 [p,

)

8、replace(InF, InL, p, cnt) 将 [InF, InL) 替换成 [p, p + cnt)

9、replace(InF, InL, n, c) 将 [InF, InL) 替换成 n * c

10、replace(InF, InL, InF2, InL2) 将 [InF, InL) 替换成 [InF2, InL2)

4)erase() 删除

1、erase(off, cnt) 从字符串 s 中删除 s [off, off + cnt)

2、erase(iter) 从字符串 s 中删除 *iter

3、erase(ItF, ItL) 从字符串 s 中删除 [ItF, ItL)

八、取出字符串

1)取得 C 风格字符串

c_str() 返回常量类型的 C 风格字符串指针,copy(ptr, cnt, off = 0) 则将指定大小的字符串复制到特定指针。data() 在 Visual C++ 7.1 中仅仅调用了 c_str() 实现。

2)取得子字符串

substr(off, cnt) 取得 s [off, off + cnt) 的副本。

3)复制子字符串

copy(p, off, cnt) 将 s [off, off + cnt) 复制到 p。

九、字符串的缓冲区管理

字符串具有类似 std::vector 的缓冲区管理界面。

size() 取得有效元素长度

max_size() 取得当前内存分配器能分配的有效空间

reserve() 为缓冲区预留空间

capacity() 取得缓冲区的容量

resize() 重设串的长度,可以为其指定初始化值

十、定义输入迭代器的尾端

向 istream_iterator 传递输入流对象以创建输入迭代器,输入迭代器持有输入流对象的指针,默认创建和读取流失败的情况下该指针被设置为 0。并且在实现输入迭代器间的 operator == 相等运算时,进行持有的流对象指针的相等比较,这样,默认创建的输入迭代器将被用于匹配输入流的结束。

* 当输入流读取失败,用户执行 if, while 条件判断时,实际上先将判断值转换成 void* 类型,或者根据 operator ! 运算符的返回结果,对输入流重载 operator void* 和 operator ! 运算符,可以定义输入流在布尔表达式中的行为,使得当流读取失败的情况下,输入迭代器可以通过布尔表达式来确认,而不是显式访问 fail() 成员函数.

代码功能:

1、输入任意行数的内容(如果你想限制最多10行,自己加个变量计数好了)。

2、不想输入时,新行直接回车,会刷新显示统计个数。

#include

阅读更多 >>>  enumerate,列举的英文

#include

#include

#include

typedef struct strs{ char str[100]; struct strs *next;}STRS;void contWord(char *str);//对字符串大小写字母计数void intput(STRS **strsHead,STRS **strsTail);//输入字符串,并显示统计结果(每输入完一行回车时,刷新数据)void prfStrs(STRS *strsHead,int tj);//打印字符串及统计结果int dCon=0;//大写字母计数int nCon=0;//数字计数int main(){ STRS *strsHead=(STRS *)malloc(sizeof(STRS)); strsHead->next=NULL; STRS *strsTail=NULL; intput(&strsHead,&strsTail); return 0;}void prfStrs(STRS *strsHead,int tj)//tj=1输出统计结果;tj=0不输出统计结果{ while(strsHead->next!=NULL) { printf("%s\n",strsHead->next->str); strsHead=strsHead->next; } if(tj==1) { printf("大写字母个数:%d\n",dCon); printf("数字输入个数:%d\n",nCon); }}void contWord(char *str){ int len=strlen(str),i; for(i=0;i

='A' && str[i]<='Z') dCon++; if(str[i]>='0' && str[i]<='9') nCon++; }}void intput(STRS **strsHead,STRS **strsTail){ STRS *strsNew; char c; while(1) { strsNew=(STRS *)malloc(sizeof(STRS)); memset(strsNew->str,0,100); if(strsNew->str[0]==0) { c=0; c=getchar(); if(c=='\n') { system("cls"); prfStrs(*strsHead,1); break; } else { strsNew->str[0]=c; } } gets(&strsNew->str[1]); strsNew->next=NULL; if((*strsHead)->next==NULL) (*strsHead)->next=strsNew; else (*strsTail)->next=strsNew; *strsTail=strsNew; contWord(strsNew->str); }}

</strlen(str)<<"个"<

</strncat(str1,str2,3)<

</strcpy(str1,str2)<

</strncpy(str1,str2,3)<

</strcpy(str1,str2)<

字符串转换整数

Animatel软件中将数字转换为整数功能的实现方法,使用的是AS3,适用于支持AS3的Flash软件。
字符串与整数、浮点数、无符号整数之间的转换常用函数
atof(将字符串转换成浮点型数)
表头文件 #include

定义函数 double atof(const char *nptr);

函数说明

atof()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('')才结 束转换,并将结果返回。参数nptr字符串可包含正负号、小数点或E(e)来表示指数部分,如123.456或123e-2。

返回值 返回转换后的浮点型数。

附加说明 atof()与使用strtod(nptr,(char**)NULL)结果相同。

范例 /* 将字符串a 与字符串b转换成数字后相加*/

#include

main()

{

char *a=”-100.23”;

char *b=”200e-2”;

float c;

c=atof(a)+atof(b);

printf(“c=%.2f\n”,c);

}

执行

c=-98.23

////////////////////////////////////////////////////////////////////

atoi(将字符串转换成整型数)

表头文件 #include

定义函数 int atoi(const char *nptr);

函数说明 atoi()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('')才结束转换,并将结果返回。

返回值 返回转换后的整型数。

附加说明 atoi()与使用strtol(nptr,(char**)NULL,10);结果相同。

范例 /* 将字符串a 与字符串b转换成数字后相加*/

#include

mian()

{

char a[]=”-100”;

char b[]=”456”;

int c;

c=atoi(a)+atoi(b);

printf(c=%d\n”,c);

}

执行

c=356

//////////////////////////////////////////////////////////////////////////

atol(将字符串转换成长整型数)

表头文件 #include

定义函数 long atol(const char *nptr);

函数说明 atol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('')才结束转换, 并将结果返回。

返回值 返回转换后的长整型数。

附加说明 atol()与使用strtol(nptr,(char**)NULL,10);结果相同。

范例 /*将字符串a与字符串b转换成数字后相加*/

#include

main()

{

char a[]=”1000000000”;

char b[]=” 234567890”;

long c;

c=atol(a)+atol(b);

printf(“c=%d\n”,c);

}

执行

c=1234567890

////////////////////////////////////////////////////////////////

gcvt(将浮点型数转换为字符串,取四舍五入)

相关函数 ecvt,fcvt,sprintf

表头文件 #include

定义函数 char *gcvt(double number,size_t ndigits,char *buf);

函 数说明 gcvt()用来将参数number转换成ASCII码字符串,参数ndigits表示显示的位数。gcvt()与ecvt()和fcvt()不同的地 方在于,gcvt()所转换后的字符串包含小数点或正负符号。若转换成功,转换后的字符串会放在参数buf指针所指的空间。

返回值 返回一字符串指针,此地址即为buf指针。

附加说明 范例 #include

main()

{

double a=123.45;

double b=-1234.56;

char *ptr;

int decpt,sign;

gcvt(a,5,ptr);

printf(“a value=%s\n”,ptr);

ptr=gcvt(b,6,ptr);

printf(“b value=%s\n”,ptr);

}

执行

a value=123.45

b value=-1234.56

///////////////////////////////////////////////////////////////////////

strtod(将字符串转换成浮点数)

表头文件 #include

定义函数 double strtod(const char *nptr,char **endptr);

函 数说明 strtod()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,到出现非数字或字符串结束时('')才结束转 换,并将结果返回。若endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr传回。参数nptr字符串可包含正负号、 小数点或E(e)来表示指数部分。如123.456或123e-2。

返回值 返回转换后的浮点型数。

附加说明 参考atof()。

范例 /*将字符串a,b,c 分别采用10,2,16 进制转换成数字*/

#include

mian()

{

char a[]=”1000000000”;

char b[]=”1000000000”;

char c[]=”ffff”;

printf(“a=%d\n”,strtod(a,NULL,10));

printf(“b=%d\n”,strtod(b,NULL,2));

printf(“c=%d\n”,strtod(c,NULL,16));

}

执行

a=1000000000

b=512

c=65535

////////////////////////////////////////////////////////////////////////////////////

strtol(将字符串转换成长整型数)

相关函数 atof,atoi,atol,strtod,strtoul

表头文件 #include

定义函数 long int strtol(const char *nptr,char **endptr,int base);

函数说明

strtol()会将参数nptr字符串根据参数base来转换成长整型数。参数base范围从2至36,或0。参数base代表采用的进制方式,如 base值为10则采用10进制,若base值为16则采用16进制等。当base值为0时则是采用10进制做转换,但遇到如'0x'前置字符则会使用 16进制做转换。一开始strtol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束 时('')结束转换,并将结果返回。若参数endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr返回。

返回值 返回转换后的长整型数,否则返回ERANGE并将错误代码存入errno中。

附加说明 ERANGE指定的转换字符串超出合法范围。

范例 /* 将字符串a,b,c 分别采用10,2,16进制转换成数字*/

#include

main()

{

char a[]=”1000000000”;

char b[]=”1000000000”;

char c[]=”ffff”;

printf(“a=%d\n”,strtol(a,NULL,10));

printf(“b=%d\n”,strtol(b,NULL,2));

printf(“c=%d\n”,strtol(c,NULL,16));

}

执行

a=1000000000

b=512

c=65535

///////////////////////////////////////////////////////////

strtoul(将字符串转换成无符号长整型数)

相关函数 atof,atoi,atol,strtod,strtol

表头文件 #include

定义函数 unsigned long int strtoul(const char *nptr,char **endptr,int base);

函数说明

strtoul()会将参数nptr字符串根据参数base来转换成无符号的长整型数。参数base范围从2至36,或0。参数base代表采用的进制 方式,如base值为10则采用10进制,若base值为16则采用16进制数等。当base值为0时则是采用10进制做转换,但遇到如'0x'前置字符 则会使用16进制做转换。一开始strtoul()会扫描参数nptr字符串,跳过前面的空格字符串,直到遇上数字或正负符号才开始做转换,再遇到非数字 或字符串结束时('')结束转换,并将结果返回。若参数endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr返回。

返回值

返回转换后的长整型数,否则返回ERANGE并将错误代码存入errno中。

附加说明

ERANGE指定的转换字符串超出合法范围。

范例

参考strtol()

toascii(将整型数转换成合法的ASCII 码字符)

相关函数

isascii,toupper,tolower

表头文件

#include

定义函数

int toascii(int c)

函数说明

toascii()会将参数c转换成7位的unsigned char值,第八位则会被清除,此字符即会被转成ASCII码字符。

返回值

将转换成功的ASCII码字符值返回。

范例

#include

main()

{

int a=217;

char b;

printf(“before toascii () : a value =%d(%c)\n”,a,a);

b=toascii(a);

printf(“after toascii() : a value =%d(%c)\n”,b,b);

}

执行

before toascii() : a value =217()

after toascii() : a value =89(Y)

////////////////////////

tolower(将大写字母转换成小写字母)

相关函数 isalpha,toupper

表头文件 #include

定义函数 int tolower(int c);

函数说明 若参数c为大写字母则将该对应的小写字母返回。

返回值 返回转换后的小写字母,若不须转换则将参数c值返回。

附加说明 范例 /* 将s字符串内的大写字母转换成小写字母*/

#include

main()

{

char s[]=”aBcDeFgH12345;!#$”;

int i;

printf(“before tolower() : %s\n”,s);

for(i=0;I
<sizeof(s);i++)
s=tolower(s);

printf(“after tolower() : %s\n”,s);

}

执行

before tolower() : aBcDeFgH12345;!#$

after tolower() : abcdefgh12345;!#$

toupper(将小写字母转换成大写字母)

相关函数 isalpha,tolower

表头文件 #include

定义函数 int toupper(int c);

函数说明若参数c为小写字母则将该对映的大写字母返回。

返回值 返回转换后的大写字母,若不须转换则将参数c值返回。

范例 /* 将s字符串内的小写字母转换成大写字母*/

#include

main()

{

char s[]=”aBcDeFgH12345;!#$”;

int i;

printf(“before toupper() : %s\n”,s);

for(i=0;I
<sizeof(s);i++)
s=toupper(s);

printf(“after toupper() : %s\n”,s);

}

执行

before toupper() : aBcDeFgH12345;!#$

after toupper() : ABCDEFGH12345;!#$

//祝你成功
</sizeof(s);i++)

</sizeof(s);i++)

C里面怎么把字符串转成数字

atof(将字符串转换成浮点型数)
相关函数 atoi,atol,strtod,strtol,strtoul
表头文件 #include

定义函数 double atof(const char *nptr);

函数说明 atof()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('\0')才结束转换,并将结果返回。参数nptr字符串可包含正负号、小数点或E(e)来表示指数部分,如123.456或123e-2。

返回值 返回转换后的浮点型数。

附加说明 atof()与使用strtod(nptr,(char**)NULL)结果相同。

范例 /* 将字符串a 与字符串b转换成数字后相加*/

#include

main()

{

char *a=”-100.23”;

char *b=”200e-2”;

float c;

c=atof(a)+atof(b);

printf(“c=%.2f\n”,c);

}

执行 c=-98.23

atoi(将字符串转换成整型数)

相关函数 atof,atol,atrtod,strtol,strtoul

表头文件 #include

定义函数 int atoi(const char *nptr);

函数说明 atoi()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('\0')才结束转换,并将结果返回。

返回值 返回转换后的整型数。

附加说明 atoi()与使用strtol(nptr,(char**)NULL,10);结果相同。

范例 /* 将字符串a 与字符串b转换成数字后相加*/

#include

mian()

{

char a[]=”-100”;

char b[]=”456”;

int c;

c=atoi(a)+atoi(b);

printf(c=%d\n”,c);

}

执行 c=356

atol(将字符串转换成长整型数)

相关函数 atof,atoi,strtod,strtol,strtoul

表头文件 #include

定义函数 long atol(const char *nptr);

函数说明 atol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('\0')才结束转换,并将结果返回。

返回值 返回转换后的长整型数。

附加说明 atol()与使用strtol(nptr,(char**)NULL,10);结果相同。

范例 /*将字符串a与字符串b转换成数字后相加*/

#include

main()

{

char a[]=”1000000000”;

char b[]=” 234567890”;

long c;

c=atol(a)+atol(b);

printf(“c=%d\n”,c);

}

执行 c=1234567890

gcvt(将浮点型数转换为字符串,取四舍五入)

相关函数 ecvt,fcvt,sprintf

表头文件 #include

定义函数 char *gcvt(double number,size_t ndigits,char *buf);

函数说明 gcvt()用来将参数number转换成ASCII码字符串,参数ndigits表示显示的位数。gcvt()与ecvt()和fcvt()不同的地方在于,gcvt()所转换后的字符串包含小数点或正负符号。若转换成功,转换后的字符串会放在参数buf指针所指的空间。

返回值 返回一字符串指针,此地址即为buf指针。

附加说明

范例 #include

main()

{

double a=123.45;

double b=-1234.56;

char *ptr;

int decpt,sign;

gcvt(a,5,ptr);

printf(“a value=%s\n”,ptr);

ptr=gcvt(b,6,ptr);

printf(“b value=%s\n”,ptr);

}

执行 a value=123.45

b value=-1234.56

strtod(将字符串转换成浮点数)

相关函数 atoi,atol,strtod,strtol,strtoul

表头文件 #include

定义函数 double strtod(const char *nptr,char **endptr);

函数说明 strtod()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,到出现非数字或字符串结束时('\0')才结束转换,并将结果返回。若endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr传回。参数nptr字符串可包含正负号、小数点或E(e)来表示指数部分。如123.456或123e-2。

返回值 返回转换后的浮点型数。

附加说明 参考atof()。

范例 /*将字符串a,b,c 分别采用10,2,16 进制转换成数字*/

#include

mian()

{

char a[]=”1000000000”;

char b[]=”1000000000”;

char c[]=”ffff”;

printf(“a=%d\n”,strtod(a,NULL,10));

printf(“b=%d\n”,strtod(b,NULL,2));

printf(“c=%d\n”,strtod(c,NULL,16));

}

执行 a=1000000000

b=512

c=65535

strtol(将字符串转换成长整型数)

相关函数 atof,atoi,atol,strtod,strtoul

表头文件 #include

定义函数 long int strtol(const char *nptr,char **endptr,int base);

函数说明 strtol()会将参数nptr字符串根据参数base来转换成长整型数。参数base范围从2至36,或0。参数base代表采用的进制方式,如base值为10则采用10进制,若base值为16则采用16进制等。当base值为0时则是采用10进制做转换,但遇到如'0x'前置字符则会使用16进制做转换。一开始strtol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束时('\0')结束转换,并将结果返回。若参数endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr返回。

返回值 返回转换后的长整型数,否则返回ERANGE并将错误代码存入errno中。

附加说明 ERANGE指定的转换字符串超出合法范围。

范例 /* 将字符串a,b,c 分别采用10,2,16进制转换成数字*/

#include

main()

{

char a[]=”1000000000”;

char b[]=”1000000000”;

char c[]=”ffff”;

printf(“a=%d\n”,strtol(a,NULL,10));

printf(“b=%d\n”,strtol(b,NULL,2));

printf(“c=%d\n”,strtol(c,NULL,16));

}

执行 a=1000000000

b=512

c=65535

strtoul(将字符串转换成无符号长整型数)

相关函数 atof,atoi,atol,strtod,strtol

表头文件 #include

定义函数 unsigned long int strtoul(const char *nptr,char **endptr,int base);

函数说明 strtoul()会将参数nptr字符串根据参数base来转换成无符号的长整型数。参数base范围从2至36,或0。参数base代表采用的进制方式,如base值为10则采用10进制,若base值为16则采用16进制数等。当base值为0时则是采用10进制做转换,但遇到如'0x'前置字符则会使用16进制做转换。一开始strtoul()会扫描参数nptr字符串,跳过前面的空格字符串,直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束时('\0')结束转换,并将结果返回。若参数endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr返回。

返回值 返回转换后的长整型数,否则返回ERANGE并将错误代码存入errno中。

附加说明 ERANGE指定的转换字符串超出合法范围。

范例 参考strtol()

toascii(将整型数转换成合法的ASCII 码字符)

相关函数 isascii,toupper,tolower

表头文件 #include

定义函数 int toascii(int c)

函数说明 toascii()会将参数c转换成7位的unsigned char值,第八位则会被清除,此字符即会被转成ASCII码字符。

返回值 将转换成功的ASCII码字符值返回。

范例 #include

main()

{

int a=217;

char b;

printf(“before toascii () : a value =%d(%c)\n”,a,a);

b=toascii(a);

printf(“after toascii() : a value =%d(%c)\n”,b,b);

}

执行 before toascii() : a value =217()

after toascii() : a value =89(Y)

tolower(将大写字母转换成小写字母)

相关函数 isalpha,toupper

表头文件 #include

定义函数 int tolower(int c);

函数说明 若参数c为大写字母则将该对应的小写字母返回。

返回值 返回转换后的小写字母,若不须转换则将参数c值返回。

附加说明

范例 /* 将s字符串内的大写字母转换成小写字母*/

#include

main()

{

char s[]=”aBcDeFgH12345;!#$”;

int i;

printf(“before tolower() : %s\n”,s);

for(i=0;I
<sizeof(s);i++)
s[i]=tolower(s[i]);

printf(“after tolower() : %s\n”,s);

}

执行 before tolower() : aBcDeFgH12345;!#$

after tolower() : abcdefgh12345;!#$

toupper(将小写字母转换成大写字母)

相关函数 isalpha,tolower

表头文件 #include

定义函数 int toupper(int c);

函数说明 若参数c为小写字母则将该对映的大写字母返回。

返回值 返回转换后的大写字母,若不须转换则将参数c值返回。

附加说明

范例 /* 将s字符串内的小写字母转换成大写字母*/

#include

main()

{

char s[]=”aBcDeFgH12345;!#$”;

int i;

printf(“before toupper() : %s\n”,s);

for(i=0;I
<sizeof(s);i++)
s[i]=toupper(s[i]);

printf(“after toupper() : %s\n”,s);

}

执行 before toupper() : aBcDeFgH12345;!#$

after toupper() : ABCDEFGH12345;!#$

int i;

char *s = "123";

sscanf(s, "%d", &i);

itoa (表示 integer to alphanumeric)是把整型数转换成字符串的一个函数。 windows环境下,在

头文件中有。

char* itoa(int value,char*string,int radix);//value: 要转换的整数,string: 转换后的字符串,radix: 转换进制数,如2,8,10,16 进制。

atoi (表示 ascii to integer)是把字符串转换成整型数的一个函数,应用在计算机程序和办公软件中。

int atoi(const char *nptr) 函数会扫描参数 nptr字符串,会跳过前面的空白字符(例如空格,tab缩进)等。

如果 nptr不能转换成 int 或者 nptr为空字符串,那么将返回 0 [1] 。特别注意,该函数要求被转换的字符串是按十进制数理解的。

atoi输入的字符串对应数字存在大小限制(与int类型大小有关),若其过大可能报错-1。

扩展资料:

参数str:要进行转换的字符串。

返回值:每个函数返回 int 值,此值由将输入字符作为数字解析而生成。 如果该输入无法转换为该类型的值,则atoi的返回值为 0。

itoa()函数:

itoa()原型: char *itoa( int value, char *string,int radix);

原型说明:

输入参数:

value:要转换的数据。

string:目标字符串的地址。

radix:转换后的进制数,可以是10进制、16进制等,范围必须在 2-36。功能:将整数value 转换成字符串存入string 指向的内存空间 ,radix 为转换时所用基数(保存到字符串中的数据的进制基数)。

返回值:函数返回一个指向 str,无错误返回。

注意:itoa不是一个标准的c函数,他是windows特有的,跨平台写程序,要用sprintf。

</sizeof(s);i++)

</sizeof(s);i++)

strtof strtod转化字符串会有精度损失吗

使用atof或strtof转化字符串时,转化后浮点数都成了四舍五入的形式。 怎...
atof是转成float类型的数,所以精度肯定会下降的,你可以使用这个strtod函数

网站数据信息

"strtod,C里面怎么把字符串转成数字"浏览人数已经达到22次,如你需要查询该站的相关权重信息,可以点击进入"Chinaz数据" 查询。更多网站价值评估因素如:strtod,C里面怎么把字符串转成数字的访问速度、搜索引擎收录以及索引量、用户体验等。 要评估一个站的价值,最主要还是需要根据您自身的需求,如网站IP、PV、跳出率等!