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编程新手教程(5) Red Hat Enterprise Linux(RHEL)环境搭建
		Unix/Linux版本号众多,我们推荐Unix/Linux刚開始学习的人选用几款典型的Unix/Linux操作系统进行学习. 通过./a.out ./Y.out运行出结果,证明C++程序编译成功.也 ... 
- Unix/Linux环境C编程新手教程(22)  C/C++怎样获取程序的执行时间
		1.问:知道程序执行时间我们能够做什么? 在<C++应用程序性能优化>一书中,假设大家读过相信大家一定对性能优化这一块很上心,文中总是对优化前后的时间对照很直观给我们一个感受. 那么我们怎 ... 
- Unix/Linux环境C编程新手教程(21)  各个系统HelloWorld跑起来效果怎样?
		版权声明:本文为博主尹成联系QQ77025077,微信18510341407原创文章,欢迎转载侵权不究. https://blog.csdn.net/yincheng01/article/detail ... 
- Unix/Linux环境C编程新手教程(12) openSUSECCPP以及Linux内核驱动开发环境搭建
		1. openSUSE是一款优秀的linux. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaXRjYXN0Y3Bw/font/5a6L5L2T/font ... 
- Unix/Linux环境C编程新手教程(24)   MySQL 5.7.4 for Red Hat Enterprise 7(RHEL7)的安装
		远观历史, MySQL的主要目的是为了可以在单处理器核心的商业服务器上执行.现在MySQL的一个变化用户可能不会注意到,那就是甲骨文已经開始又一次架构MySQL的代码,使它大量的模块化.如软件解析器, ... 
- Unix/Linux环境C编程新手教程(41) C语言库函数的文件操作具体解释
		 上一篇博客我们解说了怎样使用Linux提供的文件操作函数,本文主要解说使用C语言提供的文件操作的库函数. 1.函数介绍 fopen(打开文件) 相关函数 open,fclose 表头文件 #in ... 
- Unix/Linux环境C编程新手教程(40) 初识文件操作
		 1.函数介绍 close(关闭文件) 相关函数 open,fcntl,shutdown.unlink,fclose 表头文件 #include<unistd.h> 定义函数 int ... 
随机推荐
- jsp页面中注释 <!-- --> 和<%-- --%> 的区别
			jsp页面中注释 <!-- --> 和<%-- --%> 的区别 原创 2016年09月01日 17:55:44 标签: jsp注释 5605 今天发现一个问题:在jsp代码中 ... 
- LoadRunner中的IP欺骗的设置以及误区
			LoadRunner中的IP欺骗的设置以及误区 最近在忙着部署web性能测试的环境后,对IP欺骗进行设置,特地做个笔记,给自己的学习历程留下点足迹. 一. 什么是IP欺骗? 做什么事首先要问个为什么, ... 
- CROC 2016 - Elimination Round (Rated Unofficial Edition) F - Cowslip Collections 数论 + 容斥
			F - Cowslip Collections http://codeforces.com/blog/entry/43868 这个题解讲的很好... #include<bits/stdc++.h ... 
- bzoj 3676 后缀自动机+马拉车+树上倍增
			思路:用马拉车把一个串中的回文串个数降到O(n)级别,然后每个串在后缀自动机上倍增找个数. #include<bits/stdc++.h> #define LL long long #de ... 
- Git github webhook  自动更新/部署代码  php自动更新脚本
			这几天尝试了利用github的webhook,当代码更新到github,我们的测试服务器自动更新最新的gitbub仓库代码. 先列几个大概步骤,有时间再补充详细 1 . 服务器生成ssh key,一般 ... 
- 20169211《Linux内核原理与分析》 第十周作业
			一.Linux内核之进程地址空间学习总结 Linux内核除了要管理物理内存还需要管理虚拟内存.用户进程的地址空间就是虚拟内存的一部分.每个用户进程都独有一个地址空间.由于是虚拟化的内存,所以从每个进程 ... 
- 洛谷P4645 [COCI2006-2007 Contest#7] BICIKLI [Tarjan,拓扑排序]
			题目传送门 BICIKLI 题意翻译 给定一个有向图,n个点,m条边.请问,1号点到2号点有多少条路径?如果有无限多条,输出inf,如果有限,输出答案模10^9的余数. 两点之间可能有重边,需要看成是 ... 
- SQL注入备忘录
			备忘录(一) 拿起小本本记下常考知识点. 常用连接词 and && %23%23 且 or || %7c%7c 或 xor 非 Access 数据库: 只能爆破表名.列名获取数据.无法 ... 
- 变量覆盖漏洞学习及在webshell中的运用
			一.发生条件: 函数使用不当($$.extract().parse_str().import_request_variables()等) 开启全局变量 二.基础了解: 1.$$定义 $$代表可变变量, ... 
- 【SQL】180. Consecutive Numbers
			Write a SQL query to find all numbers that appear at least three times consecutively. +----+-----+ | ... 
