Unix/Linux环境C编程入门教程(30) 字符串操作那些事儿
- 函数介绍
rindex(查找字符串中最后一个出现的指定字符) |
|
相关函数 |
index,memchr,strchr,strrchr |
表头文件 |
#include<string.h> |
定义函数 |
char * rindex( const char *s,int c); |
函数说明 |
rindex()用来找出参数s字符串中最后一个出现的参数c地址,然后将该字符出现的地址返回。字符串结束字符(NULL)也视为字符串一部分。 |
返回值 |
如果找到指定的字符则返回该字符所在的地址,否则返回0。 |
范例 |
#include <string.h> |
执行 |
567890 |
|
|
strcasecmp(忽略大小写比较字符串) |
|
相关函数 |
bcmp,memcmp,strcmp,strcoll,strncmp |
表头文件 |
#include<string.h> |
定义函数 |
int strcasecmp (const char *s1, const char *s2); |
函数说明 |
strcasecmp()用来比较参数s1和s2字符串,比较时会自动忽略大小写的差异。 |
返回值 |
若参数s1和s2字符串相同则返回0。s1长度大于s2长度则返回大于0 的值,s1 长度若小于s2 长度则返回小于0的值。 |
范例 |
#include <string.h> |
执行 |
aBcDeF=AbCdEf |
|
|
strcat(连接两字符串) |
|
相关函数 |
bcopy,memccpy,memcpy,strcpy,strncpy |
表头文件 |
#include <string.h> |
定义函数 |
char *strcat (char *dest,const char *src); |
函数说明 |
strcat()会将参数src字符串拷贝到参数dest所指的字符串尾。第一个参数dest要有足够的空间来容纳要拷贝的字符串。 |
返回值 |
返回参数dest的字符串起始地址 |
范例 |
#include <string.h.> |
执行 |
before strcat () : string(1) |
|
|
strchr(查找字符串中第一个出现的指定字符) |
|
相关函数 |
index,memchr,rinex,strbrk,strsep,strspn,strstr,strtok |
表头文件 |
#include<string.h> |
定义函数 |
char * strchr (const char *s,int c); |
函数说明 |
strchr()用来找出参数s字符串中第一个出现的参数c地址,然后将该字符出现的地址返回。 |
返回值 |
如果找到指定的字符则返回该字符所在地址,否则返回0。 |
范例 |
#include<string.h> |
执行 |
5.68E+25 |
|
|
strcmp(比较字符串) |
|
相关函数 |
bcmp,memcmp,strcasecmp,strncasecmp,strcoll |
表头文件 |
#include<string.h> |
定义函数 |
int strcmp(const char *s1,const char *s2); |
函数说明 |
strcmp()用来比较参数s1和s2字符串。字符串大小的比较是以ASCII 码表上的顺序来决定,此顺序亦为字符的值。strcmp()首先将s1第一个字符值减去s2第一个字符值,若差值为0则再继续比较下个字符,若差值不为0则将差值返回。例如字符串"Ac"和"ba"比较则会返回字符"A"(65)和'b'(98)的差值(-33)。 |
返回值 |
若参数s1和s2字符串相同则返回0。s1若大于s2则返回大于0的值。s1若小于s2则返回小于0 的值。 |
范例 |
#include<string.h> |
执行 |
strcmp(a,b) : 32 |
|
|
strcoll(采用目前区域的字符排列次序来比较字符串) |
|
相关函数 |
strcmp,bcmp,memcmp,strcasecmp,strncasecmp |
表头文件 |
#include<string.h> |
定义函数 |
int strcoll( const char *s1, const char *s2); |
函数说明 |
strcoll()会依环境变量LC_COLLATE所指定的文字排列次序来比较s1和s2 字符串。 |
返回值 |
若参数s1和s2字符串相同则返回0。s1若大于s2则返回大于0的值。s1若小于s2则返回小于0 的值。 |
附加说明 |
若LC_COLLATE为"POSIX"或"C",则strcoll()与strcmp()作用完全相同。 |
范例 |
参考strcmp()。 |
|
|
strcpy(拷贝字符串) |
|
相关函数 |
bcopy,memcpy,memccpy,memmove |
表头文件 |
#include<string.h> |
定义函数 |
char *strcpy(char *dest,const char *src); |
函数说明 |
strcpy()会将参数src字符串拷贝至参数dest所指的地址。 |
返回值 |
返回参数dest的字符串起始地址。 |
附加说明 |
如果参数dest所指的内存空间不够大,可能会造成缓冲溢出(buffer Overflow)的错误情况,在编写程序时请特别留意,或者用strncpy()来取代。 |
范例 |
#include<string.h> |
执行 |
before strcpy() :string(1) |
|
|
strcspn(返回字符串中连续不含指定字符串内容的字符数) |
|
相关函数 |
strspn |
表头文件 |
#inclued<string.h> |
定义函数 |
size_t strcspn ( const char *s,const char * reject); |
函数说明 |
strcspn()从参数s字符串的开头计算连续的字符,而这些字符都完全不在参数reject 所指的字符串中。简单地说,若strcspn()返回的数值为n,则代表字符串s开头连续有n个字符都不含字符串reject内的字符。 |
返回值 |
返回字符串s开头连续不含字符串reject内的字符数目。 |
范例 |
#include <string.h> |
执行 |
5 /*只计算到" "的出现,所以返回"Linux"的长度*/ |
|
|
strdup(复制字符串) |
|
相关函数 |
calloc,malloc,realloc,free |
表头文件 |
#include<string.h> |
定义函数 |
char * strdup( const char *s); |
函数说明 |
strdup()会先用maolloc()配置与参数s字符串相同的空间大小,然后将参数s字符串的内容复制到该内存地址,然后把该地址返回。该地址最后可以利用free()来释放。 |
返回值 |
返回一字符串指针,该指针指向复制后的新字符串地址。若返回NULL表示内存不足。 |
范例 |
#include<string.h> |
执行 |
b[ ]="strdup" |
|
|
strlen(返回字符串长度) |
|
相关函数 |
|
表头文件 |
#include<string.h> |
定义函数 |
size_t strlen (const char *s); |
函数说明 |
strlen()用来计算指定的字符串s的长度,不包括结束字符"\0"。 |
返回值 |
返回字符串s的字符数。 |
范例 |
/*取得字符串str的长度*/ |
执行 |
str length = 8 |
|
|
strncasecmp(忽略大小写比较字符串) |
|
相关函数 |
bcmp,memcmp,strcmp,strcoll,strncmp |
表头文件 |
#include<string.h> |
定义函数 |
int strncasecmp(const char *s1,const char *s2,size_t n); |
函数说明 |
strncasecmp()用来比较参数s1和s2字符串前n个字符,比较时会自动忽略大小写的差异。 |
返回值 |
若参数s1和s2 字符串相同则返回0。s1 若大于s2则返回大于0的值,s1若小于s2则返回小于0 的值。 |
范例 |
#include<string.h> |
执行 |
aBcDef=AbCdEf |
|
|
strncat(连接两字符串) |
|
相关函数 |
bcopy,memccpy,memecpy,strcpy,strncpy |
表头文件 |
#inclue <string.h> |
定义函数 |
char * strncat(char *dest,const char *src,size_t n); |
函数说明 |
strncat()会将参数src字符串拷贝n个字符到参数dest所指的字符串尾。第一个参数dest要有足够的空间来容纳要拷贝的字符串。 |
返回值 |
返回参数dest的字符串起始地址。 |
范例 |
#include <string.h> |
执行 |
before strnact() : string(1) |
|
|
strncpy(拷贝字符串) |
|
相关函数 |
bcopy,memccpy,memcpy,memmove |
表头文件 |
#include<string.h> |
定义函数 |
char * strncpy(char *dest,const char *src,size_t n); |
函数说明 |
strncpy()会将参数src字符串拷贝前n个字符至参数dest所指的地址。 |
返回值 |
返回参数dest的字符串起始地址。 |
范例 |
#inclue <string.h> |
执行 |
before strncpy() : string(1) |
|
|
strpbrk(查找字符串中第一个出现的指定字符) |
|
相关函数 |
index,memchr,rindex,strpbrk,strsep,strspn,strstr,strtok |
表头文件 |
#include <include.h> |
定义函数 |
char *strpbrk(const char *s,const char *accept); |
函数说明 |
strpbrk()用来找出参数s 字符串中最先出现存在参数accept 字符串中的任意字符。 |
返回值 |
如果找到指定的字符则返回该字符所在地址,否则返回0。 |
范例 |
#include <string.h> |
执行 |
1.23E+29 |
|
|
strrchr(查找字符串中最后出现的指定字符) |
|
相关函数 |
index,memchr,rindex,strpbrk,strsep,strspn,strstr,strtok |
表头文件 |
#include<string.h> |
定义函数 |
char * strrchr(const char *s, int c); |
函数说明 |
strrchr()用来找出参数s字符串中最后一个出现的参数c地址,然后将该字符出现的地址返回。 |
返回值 |
如果找到指定的字符则返回该字符所在地址,否则返回0。 |
范例 |
#include<string.h> |
执行 |
567890 |
|
|
strspn(返回字符串中连续不含指定字符串内容的字符数) |
|
相关函数 |
strcspn,strchr,strpbrk,strsep,strstr |
表头文件 |
#include<string.h> |
定义函数 |
size_t strspn (const char *s,const char * accept); |
函数说明 |
strspn()从参数s 字符串的开头计算连续的字符,而这些字符都完全是accept 所指字符串中的字符。简单的说,若strspn()返回的数值为n,则代表字符串s 开头连续有n 个字符都是属于字符串accept内的字符。 |
返回值 |
返回字符串s开头连续包含字符串accept内的字符数目。 |
范例 |
#include<string.h> |
执行 |
5 /*计算大小写字母。不包含" ",所以返回Linux的长度。*/ |
|
|
strstr(在一字符串中查找指定的字符串) |
|
相关函数 |
index,memchr,rindex,strchr,strpbrk,strsep,strspn,strtok |
表头文件 |
#include<string.h> |
定义函数 |
char *strstr(const char *haystack,const char *needle); |
函数说明 |
strstr()会从字符串haystack 中搜寻字符串needle,并将第一次出现的地址返回。 |
返回值 |
返回指定字符串第一次出现的地址,否则返回0。 |
范例 |
#include<string.h> |
执行 |
9.01E+21 |
|
|
strtok(分割字符串) |
|
相关函数 |
index,memchr,rindex,strpbrk,strsep,strspn,strstr |
表头文件 |
#include<string.h> |
定义函数 |
char * strtok(char *s,const char *delim); |
函数说明 |
strtok()用来将字符串分割成一个个片段。参数s指向欲分割的字符串,参数delim则为分割字符串,当strtok()在参数s的字符串中发现到参数delim的分割字符时则会将该字符改为\0 字符。在第一次调用时,strtok()必需给予参数s字符串,往后的调用则将参数s设置成NULL。每次调用成功则返回下一个分割后的字符串指针。 |
返回值 |
返回下一个分割后的字符串指针,如果已无从分割则返回NULL。 |
范例 |
#include<string.h> |
执行 |
ab cd ef;gh i jkl;mnop;qrs tu vwx y;z /*-与:字符已经被\0 字符取代*/ |
- 关于strlen()和sizeof()
首先strlen是函数,sizeof是运算符sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型
。
Sizeof()
编译时计算,参数可以是数组、指针、类型、对象、函数等。
它的功能是:获得保证能容纳实现所建立的最大对象的字节大小。
所以,sizeof不能用来返回动态分配的内存空间的大小。
实际上,用sizeof来返回类型以及静态分配的对象、结构或数组所占的空间,返回值跟对象、结构、数组所存储的内容没有关系。
Strlen()
参数必须是字符型指针(char*), 且必须是以'\0'结尾的。当数组名作为参数传入时,实际上数组就退化成指针了。
如果你的缓冲区中没有以'\0'结束,那么strlen()计算的时候就会溢出到时数字很大,大到你吓一跳。
2.小试牛刀
现在得把上面常用的字符串函数给摘过来,练练。
首先我们得构思一个程序流程出来:
申请一段堆空间p 和一段栈空间
用栈空间的缓存区接收一段来自屏幕的字符串输入
将字符串中的小写拷贝到p 并全部改成大写
若是出现'%'这个字符 我们将其及其后2个字符全部拷贝到p那里去
在其中若是找到ABC的字串就在拷贝到p的时候替换成$
源代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
int main(void)
{
char flag1 = '%';
char flag2 = '$';
//申请一段堆空间p 和一段栈空间
char buffer[32];
char *q,*r;
printf("内存开始分配\n");
char *p = (char *)malloc(32*sizeof(char));
printf("内存清零完成\n");
memset(p,0,32);
//用栈空间的缓存区接收一段来自屏幕的字符串输入
printf("请输入字符串:");
scanf("%s",buffer);
q = p;
r = buffer; while(q || r)
{
if(*r == '\0')
break;
//将字符串中的小写拷贝到p 并全部改成大写
//isupper(测试字符是否为小写英文字母)
if(islower(*r))
{
printf("找到了一个小写字母\n");
*q++ = toupper(*r++);
}
//若是出现'%'这个字符 不管其后大小写情况如何我们将其及其后3个字符全部拷贝到p那里去
//int strcmp(const char *s1,const char *s2);
else if( strncmp(r,&flag1,1) == 0)
{
printf("找到了一个%%\n");
//char * strncpy(char *dest,const char *src,size_t n);
strncpy(q,r,3);
q += 3;
r += 3;
}
/*
* 在其中若是找到ABC的字串就在当前q的位置插入一个$
* 需要ABC的起始地址是当前为位置
*/ //char *strstr(const char *haystack,const char *needle);
else if(strstr(r,"ABC") == r )
{
printf("找到一次ABC\n");
//char *strcpy(char *dest,const char *src);
strncpy(q++,&flag2,1);
r += 3;
} else
q++,r++; } //输出最后的字符
printf("最后的字符串已经变成:%s\n",p); //释放内存
free(p);
printf("内存释放完毕\n");
return 0;
}
3.各个平台运行效果
在RHEL7上
在RHEL6上
在MAC上
在Solaris11上
Unix/Linux环境C编程入门教程(30) 字符串操作那些事儿的更多相关文章
- Unix/Linux环境C编程新手教程(30) 字符串操作那些事儿
函数介绍 rindex(查找字符串中最后一个出现的指定字符) 相关函数 index,memchr,strchr,strrchr 表头文件 #include<string.h> 定义函数 c ...
- Unix/Linux环境C编程入门教程(29) 内存操作那些事儿
函数介绍 memccpy(拷贝内存内容) 相关函数 bcopy,memcpy,memmove,strcpy,strncpy 表头文件 #include<string.h> 定义函数 voi ...
- Unix/Linux环境C编程入门教程(23) 字符数字那些事儿
1.atoi 包含头文件: #include <stdlib.h> 函数原型: int atoi( const char *str ); 功能:将字符串str转换成一个整数并返回结果.参数 ...
- Unix/Linux环境C编程入门教程(28) 日期时间那些事儿
记得这个专题第一篇我们写过一个程序运行时间的程序,采用库函数提供的clock()模拟做程序测试.本篇介绍的函数也是和时间相关,但是没有clock的细致,而是提供的系统时间和日期. 1.asctime( ...
- Unix/Linux环境C编程入门教程(26) 字符数字那些事儿
1.gcvt() strtod() strtol() strtoul() toascii() tolower() toupper函数介绍 gcvt(将浮点型数转换为字符串,取四舍五入) 相关函数 ec ...
- Unix/Linux环境C编程入门教程(32) 环境变量那些事儿
1. getenv() putenv()setenv()函数介绍 getenv(取得环境变量内容) 相关函数 putenv,setenv,unsetenv 表头文件 #include<stdli ...
- Unix/Linux环境C编程入门教程(19)Red Hat Entetprise Linux 7.0环境搭建
位架构,包括英特尔X-86_64.Power和s390.动态定时能力将降低内核内部中断数量,Open vSwitch 2.0功能可调节虚拟机之间的流量.RHEL 7中默认的文件系统是XFS,包含了一个 ...
- Unix/Linux环境C编程入门教程(5) Red Hat Enterprise Linux(RHEL)环境搭建
Unix/Linux版本众多,我们推荐Unix/Linux初学者选用几款典型的Unix/Linux操作系统进行学习. 通过./a.out ./Y.out执行出结果,证明C++程序编译成功,也就说明li ...
- Unix/Linux环境C编程入门教程(4) Debian Linux环境搭建
Unix/Linux版本众多,我们推荐Unix/Linux初学者选用几款典型的Unix/Linux操作系统进行学习. 1.广义的Debian是指一个致力于创建自由操作系统的合作组织及其作品,由于Deb ...
随机推荐
- poj 1129 Channel Allocation
http://poj.org/problem?id=1129 import java.util.*; import java.math.*; public class Main { public st ...
- USB枚举过程的详细流程
USB枚举过程的详细流程 用户将一个USB设备插入USB端口,主机为端口供电,设备此时处于上电状态.主机检测设备.1>Hub使用中断通道将事件报告给Host.2>Host发送Get_Por ...
- USB系列之三:从你的U盘里读出更多的内容
U盘是我们最常使用的一种USB设备,本文继续使用DOSUSB做驱动,试图以读取扇区的方式读取你的U盘.本文可能涉及的协议可能会比较多. 一.了解你的U盘 首先我们用上一篇文章介绍的程序usbvi ...
- SqlServer sys.partition_view
--查看partition的四个视图 select * from sys.partition_functions--查看分区函数 select * from sys.partition_paramet ...
- Linux删除乱码文件或者目录
Linux删除乱码文件或者目录 有时在Linux下面解压一些zip或者rar文件后会产生乱码文件或者目录,这个时候使用rm不能成功删除,需要使用一些特别的方法 来进行删除,下面是我经常使用的两种方法. ...
- UESTC_韩爷的情书 2015 UESTC Training for Graph Theory<Problem H>
H - 韩爷的情书 Time Limit: 6000/2000MS (Java/Others) Memory Limit: 262144/262144KB (Java/Others) Subm ...
- HDU5441 Travel (离线操作+并查集)
Travel Time Limit: 1500/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total Su ...
- 正则表达式、find、grep、awk、sed
1.正则表达式 (1)正则表达式一般用来描述文本模式的特殊用法,由普通字符(例如字符a-z)以及特殊字符(称为元字符,如/.*.?等)组成. (2)基本元字符集及其含义 ^ :只 ...
- 【巧妙算法系列】【Uva 11464】 - Even Parity 偶数矩阵
偶数矩阵(Even Parity, UVa 11464) 给你一个n×n的01矩阵(每个元素非0即1),你的任务是把尽量少的0变成1,使得每个元素的上.下.左.右的元素(如果存在的话)之和均为偶数.比 ...
- EF 事务处理 (InnoDB Engine的MySQL表也可以)
备忘 1. 亲测(可以嵌套使用) using (TransactionScope scope = new TransactionScope()) { //操作1 XXEntities.Current. ...