C语言中常用的字符串处理函数总结
C语言中字符串处理函数备注
此文仅用于自己研究和记录
字符串处理函数
1. char *gets(char *s);
#include<stdio.h>
功能: 从标准输入读入字符,并保存到s指定的内存空间,直到出现换行符或读到文件结尾为止
参数:
- s:字符串首地址
返回值: 成功:读入的字符串 失败:NULL
gets(str)与scanf(“%s”,str)的区别:
- gets(str)允许输入的字符串含有空格
- scanf(“%s”,str)不允许含有空格
注意:
由于scanf()和gets()无法知道字符串s大小,必须遇到换行符或读到文件结尾为止才接收输入,因此容易导致字符数组越界(缓冲区溢出)的情况。
举例:
printf("请输入str: ");
gets(str);
printf("str = %s\n", str);
2. char *fgets(char *s, intsize, FILE *stream);
#include<stdio.h>
功能: 从stream指定的文件内读入字符,保存到s所指定的内存空间,直到出现换行字符、读到文件结尾或是已读了size - 1个字符为止,最后会自动加上字符 '\0' 作为字符串结束
参数:
- s:字符串
- size:指定最大读取字符串的长度(size - 1)
- stream:文件指针,如果读键盘输入的字符串,固定写为stdin
返回值:
- 成功:成功读取的字符串
- 读到文件尾或出错: NULL
描述:
fgets()在读取一个用户通过键盘输入的字符串的时候,同时把用户输入的回车也做为字符串的一部分。通过scanf和gets输入一个字符串的时候,不包含结尾的“\n”,但通过fgets结尾多了“\n”。fgets()函数是安全的,不存在缓冲区溢出的问题。
举例:
charstr[100];
printf("请输入str: ");
fgets(str, sizeof(str), stdin);
printf("str = \"%s\"\n", str);
3. int puts(const char *s);
#include<stdio.h>
功能: 标准设备输出s字符串,在输出完成后自动输出一个'\n'。
参数: s:字符串首地址。
返回值:
- 成功:非负数
- 失败:-1
举例:
# include <stdio.h>
int main()
{
printf("hello world");
puts("hello world");
return 0;
}
4. int fputs(const char *str, FILE *stream);
#include<stdio.h>
功能: 将str所指定的字符串写入到stream指定的文件中,字符串结束符'\0'不写入文件。
参数:
- str:字符串
- stream:文件指针,如果把字符串输出到屏幕,固定写为stdout。
返回值:
- 成功:0
- 失败:-1
注意:
fputs()是puts()的文件操作版本,但fputs() 不会自动输出一个'\n'。
举例:
printf("hello world");
puts("hello world");
fputs("hello world", stdout);
5. size_t strlen(const char *s);
#include<string.h>
功能: 计算指定指定字符串s的长度,不包含字符串结束符‘\0’.
参数: s:字符串首地址
返回值: 字符串s的长度,size_t 为unsigned int类型
举例:
char str[] = "abcdefg";
int n = strlen(str);
printf("n = %d\n", n);
6. char *strcpy(char *dest, const char *src);
#include<string.h>
功能: 把src所指向的字符串复制到dest所指向的空间中,'\0'也会拷贝过去
参数:
- dest:目的字符串首地址
- src:源字符首地址
返回值:
- 成功:返回dest字符串的首地址
- 失败:NULL
注意: 如果参数dest所指的内存空间不够大,可能会造成缓冲溢出的错误情况。
举例:
char dest[20] = "123456789";
char src[] = "hello world";
strcpy(dest, src);
printf("%s\n", dest);
7. char *strncpy(char *dest, const char *src, size_tn);
#include<string.h>
功能: 把src指向字符串的前n个字符复制到dest所指向的空间中,是否拷贝结束符看指定的长度是否包含'\0'。
参数:
- dest:目的字符串首地址
- src:源字符首地址
- n:指定需要拷贝字符串个数
返回值:
- 成功:返回dest字符串的首地址
- 失败:NULL
举例:
char dest[20] ;
char src[] = "hello world";
strncpy(dest, src, 5);
printf("%s\n", dest);
dest[5] = '\0';
printf("%s\n", dest);
8. char *strcat(char *dest, const char *src);
#include<string.h>
功能: 将src字符串连接到dest的尾部,‘\0’也会追加过去
参数:
- dest:目的字符串首地址
- src:源字符首地址
返回值:
- 成功:成功:返回dest字符串的首地址
- 失败:NULL
举例:
char str[20] = "123";
char *src = "hello world";
printf("%s\n", strcat(str, src));
9. char *strncat(char *dest, const char *src, size_tn);
#include<string.h>
功能: 将src字符串前n个字符连接到dest的尾部,‘\0’也会追加过去
参数:
- dest:目的字符串首地址
- src:源字符首地址
- n:指定需要追加字符串个数
返回值:
- 成功:成功:返回dest字符串的首地址
- 失败:NULL
举例:
char str[20] = "123";
char *src = "hello world";
printf("%s\n", strncat(str, src, 5));
10. int strcmp(const char *s1, const char *s2);
#include<string.h>
功能: 比较 s1 和 s2 的大小,比较的是字符ASCII码大小。
参数:
- s1:字符串1首地址
- s2:字符串2首地址
返回值:
- 相等:0
- 大于:>0
- 小于:<0
举例:
char *str1 = "hello world";
char *str2 = "hello mike";
if (strcmp(str1, str2) == 0)
{
printf("str1==str2\n");
}
elseif (strcmp(str1, str2) > 0)
{
printf("str1>str2\n");
}
else
{
printf("str1<str2\n");
}
11. int strncmp(const char *s1, const char *s2, size_tn);
#include<string.h>
功能: 比较 s1 和 s2 前n个字符的大小,比较的是字符ASCII码大小。
参数:
- s1:字符串1首地址
- s2:字符串2首地址
- n:指定比较字符串的数量
返回值:
- 相等:0
- 大于:>0
- 小于:<0
举例:
char *str1 = "hello world";
char *str2 = "hello mike";
if (strncmp(str1, str2, 5) == 0)
{
printf("str1==str2\n");
}
elseif (strcmp(str1, "hello world") > 0)
{
printf("str1>str2\n");
}
else
{
printf("str1<str2\n");
}
12. int sprintf(char *str , const char *format, ...);
#include<stdio.h>
功能: 根据参数format字符串来转换并格式化数据,然后将结果输出到str指定的空间中,直到出现字符串结束符 '\0' 为止。
参数:
- str:字符串首地址
- format:字符串格式,用法和printf()一样
返回值:
- 成功:实际格式化的字符个数
- 失败: - 1
举例:
char dst[100] = { 0 };
int a = 10;
char src[] = "hello world";
printf("a = %d, src = %s", a, src);
printf("\n");
int len = sprintf(dst, "a = %d, src = %s", a, src);
printf("dst = \" %s\"\n", dst);
printf("len = %d\n", len);
13. int sscanf(const char *str, const char *format, ...);
#include<stdio.h>
功能: 从str指定的字符串读取数据,并根据参数format字符串来转换并格式化数据。
参数:
- str:指定的字符串首地址
- format:字符串格式,用法和scanf()一样
返回值:
- 成功:参数数目,成功转换的值的个数
- 失败: - 1
举例:
char src[] = "a=10, b=20";
int a;
int b;
sscanf(src, "a=%d, b=%d", &a, &b);
printf("a:%d, b:%d\n", a, b);
14. char *strchr(const char *s, intc);
#include<string.h>
功能: 在字符串s中查找字母c出现的位置。
参数:
- s:字符串首地址
- c:匹配字母(字符)
返回值:
- 成功:返回第一次出现的c地址
- 失败: NULL
举例:
char src[] = "ddda123abcd";
char *p = strchr(src, 'a');
printf("p = %s\n", p);
15. char *strstr(const char *haystack, const char *needle);
#include<string.h>
功能: 在字符串haystack中查找字符串needle出现的位置。
参数:
- haystack:源字符串首地址
- needle:匹配字符串首地址
返回值:
- 成功:返回第一次出现的needle地址
- 失败: NULL
举例:
char src[] = "ddddabcd123abcd333abcd";
char *p = strstr(src, "abcd");
printf("p = %s\n", p);
16. char *strtok(char *str, const char *delim);
#include<string.h>
功能: 来将字符串分割成一个个片段。当strtok()在参数s的字符串中发现参数delim中包含的分割字符时, 则会将该字符改为\0 字符,当连续出现多个时只替换第一个为\0。
参数:
- str:指向欲分割的字符串
- delim:为分割字符串中包含的所有字符
返回值:
- 成功:分割后字符串首地址
- 失败: NULL
举例:
char a[100] = "adc*fvcv*ebcy*hghbdfg*casdert";
char *s = strtok(a, "*");//将"*"分割的子串取出
while (s != NULL)
{
printf("%s\n", s);
s = strtok(NULL, "*");
}
17. int atoi(const char *nptr);
#include<stdlib.h>
功能: atoi()会扫描 nptr字符串, 跳过前面的 空格字符,直到遇到 数字或 正负号才开始做 转换,而遇到 非数字或 字符串结束符('\0')才 结束转换,并将结果返回 返回值。
参数:
- nptr:待转换的字符串
返回值:
- 成功:转换后整数
类似的函数有:
- atof():把一个小数形式的字符串转化为一个浮点数。
- atol():将一个字符串转化为long类型
举例:
char str1[] = "-10";
int num1 = atoi(str1);
printf("num1 = %d\n", num1);
char str2[] = "0.123";
double num2 = atof(str2);
printf("num2 = %lf\n", num2);
C语言中常用的字符串处理函数总结的更多相关文章
- C语言中常用的字符串操作函数
程序开头要声明 #include <string.h> 函数名: stpcpy 功 能: 拷贝一个字符串到另一个 用 法: char *stpcpy(char *destin, char ...
- LoadRunner中常用的字符串操作函数
LoadRunner中常用的字符串操作函数有: strcpy(destination_string, source_string); strc ...
- php中常用的字符串查找函数strstr()、strpos()实例解释
string strstr ( string $haystack , mixed $needle [, bool $before_needle = false ] ) 1.$haystack被查找的字 ...
- 【linux C】C语言中常用的几个函数的总结【二】
3.fgets 虽然用 gets() 时有空格也可以直接输入,但是 gets() 有一个非常大的缺陷,即它不检查预留存储区是否能够容纳实际输入的数据,换句话说,如果输入的字符数目大于数组的长度,get ...
- PHP开发中常用的字符串操作函数
1,拼接字符串 拼接字符串是最常用到的字符串操作之一,在PHP中支持三种方式对字符串进行拼接操作,分别是圆点.分隔符{}操作,还有圆点等号.=来进行操作,圆点等号可以把一个比较长的字符串分解为几行进行 ...
- PHP中常用的字符串格式化函数总结
注意:在PHP中提供的字符串函数处理的字符串,大部分都不是在原字符串上修改,而是返回一个格式化后的新字符串. 一.取出空格和字符串填补函数 空格也是一个有效的字符,在字符串中也会占据一个位置.用户在表 ...
- ASP.NET中常用的字符串分割函数
asp.net字符串分割函数用法 先来看个简单的实例 但是其数组长度却是25,而不是3.下面这种方法是先将“[111cn.net]”替换成一个特殊字符,比如$,在根据这个字符执行Split 例如下面我 ...
- 【linux C】C语言中常用的几个函数的总结【一】
1.memset函数 定义变量时一定要进行初始化,尤其是数组和结构体这种占用内存大的数据结构.在使用数组的时候经常因为没有初始化而产生“烫烫烫烫烫烫”这样的野值,俗称“乱码”.每种类型的变量都有各自的 ...
- SQL中常用的字符串LEFT函数和RIGHT函数详解!
今天继续整理日常可能经常遇到的一些处理字符串的函数,记得点赞收藏!以备不时之需!看到最后有惊喜! LEFT(expression, length)函数 解析:从提供的字符串的左侧开始提取给定长度的字符 ...
随机推荐
- Android Studio 配置快速生成模板代码
前言 Android studio 有提供快速生成模板代码的功能,其实这个功能也可以自定义配置.此篇博客将讲解如何使用此功能 进入Settings 选择 Editor > Live Templa ...
- 十一. for of
const fruits = ['Apple','Banana','Orange','Mango']; es5: 可读性差 for(let i=0; i < fruits.length; i + ...
- Altera的primary register和secondary register
在Altera的一些IP文档上,提到IP的资源使用情况时,会有primary logic register和secondary logic register这样的术语. 那么什么是primary/se ...
- day21 生成器,列表解析,三元表达式
Python之路,Day9 = Python基础9 判断可迭代对象和迭代器 from collections import Iterable, Iterator # 导入模块功能,用来判断对象是否为I ...
- thinkphp 使用php代码
Php代码可以和标签在模板文件中混合使用,可以在模板文件里面书写任意的PHP语句代码 ,包括下面两种方式: 直线电机选购 第一种:使用php标签 例如: <php>echo 'Hello, ...
- Byte[]和Stream相互转换
C# Stream 和 byte[] 之间的转换 一. 二进制转换成图片 MemoryStream ms = new MemoryStream(bytes); ms.Position = 0; Ima ...
- webpack官方文档学习
一.webpack是什么? webpack是一款模块加载器兼打包工具,它能把各种资源,例如JS(含JSX).coffee.样式(含less/sass).图片等都作为模块来使用和处理. 二.安装 前提条 ...
- 02-Nov-2017 07:11:56.475 信息 [http-nio-8080-exec-10] com.mchange.v2.c3p0.impl.AbstractPoolBackedDataSource. Initializing c3p0 pool...
报错: 02-Nov-2017 07:11:56.475 信息 [http-nio-8080-exec-10] com.mchange.v2.c3p0.impl.AbstractPoolBackedD ...
- USART 串口
串口不工作 请逐一检查: 是否正确配置复用IO口(先用RCC_APB2PeriphClockCmd在RCC寄存器中先开启GPIOx的时钟使能,再用 GPIO_Init 进行IO复用配置) 是否正确配置 ...
- PAT甲级——A1123 Is It a Complete AVL Tree【30】
An AVL tree is a self-balancing binary search tree. In an AVL tree, the heights of the two child sub ...