“String.h” 源代码总结
<String.h> 总结:
常用的函数:
一、memchr:
说明:当第一次遇到字符ch时停止查找。如果成功,返回指向字符ch的指针;否则返回NULL。
代码:
#include <stdio.h>
void *memchr(const void*s, int c, size_t n){
const unsigned char uc = c;
const unsigned char *su;
< n; ++su, --n)
if(*su == uc)
return ((void *)su);
return (NULL);
}
int main(int argc, char const *argv[])
{
char*s ="I am Levi !";
char *p;
p );
if(p) printf("%s\n", p);
else printf("Not Found!\n");
;
}
// find first occurrence if c in s[n].
二、memcmp:
说明:比较内存区域buf1和buf2的前count个字节
代码:
#include <stdio.h>
int memcmp(const void *s1, const void *s2, size_t n){
const unsigned char *su1, *su2;
< n; ++su1, ++su2, --n)
if(*su1 != *su2)
return ((*su1 < *su2) ? -1 : +1);
;
}
int main(int argc, char const *argv[])
{
char*s1 ="Cello kitty1";
char*s2 ="Dello kitty";
int r;
r );
if(!r) printf("s1 and s2 are identical\n");
) printf("s1 less than s2\n");
else printf("s1 greater than s2\n");
;
}
//compare unsigned char (s1[n] and s2[n]).
三、memcpy
说明:由src所指内存区域复制count个字节到dest所指内存区域
代码:
#include <stdio.h>
void *memcpy(void *s1, const void *s2, size_t n){
char *su1;
const char *su2;
< n; ++su1, ++su2, --n)
*su1 = *su2;
return (s1);
}
int main(int argc, char const *argv[])
{
char*s ="Hello Levi";
];
memcpy(d, s, );
printf("%s\n", d);
puts(d);
;
}
/* copy char s2[n] to s1[n] in any order */
四、memmove
说明:
1、由src所指内存区域复制count个字节到dest所指内存区域。
2、src和dest所指内存区域可以重叠,但复制后src内容会被更改。函数返回指向dest的指针。
代码:
#include <stdio.h>
void *memmove(void *s1, const void *s2, size_t n){
char *sc1;
const char *sc2;
sc1 = s1;
sc2 = s2;
if(sc2 > sc1 && sc1 < sc2 + n)
< n; --n)
*--sc1 = *--sc2;
else
< n; --n)
*sc1++ = *sc2++;
return (s1);
}
int main(int argc, char const *argv[])
{
char s[] ="wushirenfei shitaiyanliang";
memmove(s, s);
printf("%s\n", s);
;
}
/* copy char s2[n] to s1[n] safely */
五、memset
说明:
1、把buffer所指内存区域的前count个字节设置成字符c。
2、返回指向buffer的指针。
代码:
#include <stdio.h>
void *memset(void *s, int c, size_t n){
const unsigned char uc = c;
unsigned char *su;
< n; ++su, --n)
*su = uc;
return (s);
}
int main(int argc, char const *argv[])
{
] ="Bu xiang yan hua lu shang xing";
memset(s);
printf("%s\n", s);
;
}
六、strncat、strcat
说明:
1、strcat 把src所指字符串添加到dest结尾处并添加'\0'。
2、src、dest 不可以重叠
代码:
#include <stdio.h>
char *strncat(char *s1, const char *s2, size_t n){
char *s;
for(s = s1; *s != '\0'; ++s)
;
< n && *s2 != '\0'; --n)
*s++ = *s2++;
*s = '\0';
return (s1);
}
char *strcat(char *s1, const char *s2){
char *s;
for(s = s1; *s != '\0'; ++s)
;
for(; (*s = *s2) != '\0'; ++s, ++s2)
;
return s1;
}
int main()
{
]="Golden Global";
char *s=" View WinIDE Library";
strcat(d,s);
printf("%s\n",d);
;
}
七、strcpy、strncpy
说明:
1、把src所指由NULL结束的字符串复制到dest所指的数组中
2、src和dest所指内存区域不可以重叠
代码:
#include <stdio.h>
char *strcpy(char *s1, const char *s2){
char *s;
for(s = s1; (*s++ = *s2++) != '\0'; )
;
return (s1);
}
char *strncpy(char *s1, const char *s2, size_t n){
char *s;
< n && *s2 != '\0'; --n)
*s++ = *s2++;
< n; --n)
*s++ = '\0';
return s1;
}
int main(int argc, char const *argv[])
{
char*s ="Levi is Hacker";
];
strcpy(d, s);
printf("%s\n", d);
;
}
八、strcmp、strncmp
说明:
1、比较字符串s1和s2
2、如何比较,看代码吧
代码:
#include <stdio.h>
int strncmp(const char *s1, const char *s2, size_t n){
< n; ++s1, ++s2, --n)
if(*s1 != *s2)
return((*(unsigned char *)s1 < *(unsigned char *)s2) ? -1 : +1);
else if(*s1 == '\0')
;
;
}
int strcmp(const char *s1, const char *s2){
for(; *s1 == *s2; ++s1, ++s2)
if(*s1 == '\0')
;
return ((*(unsigned char *)s1 < *(unsigned char *)s2) ? -1 : +1);
}
int main(int argc, char const *argv[])
{
char *s1="Ze";
char *s2="Hel";
int r;
r = strcmp(s1, s2);
if(!r)
printf("s1 and s2 are identical\n");
else
if(r<0)
printf("s1 less than s2\n");
else
printf("s1 greater than s2\n");
;
}
九、strlen
说明:返回字符串长度
代码:
#include <stdio.h>
size_t strlen(const char*s){
const char *sc;
for(sc = s; *sc != '\0'; ++sc)
;
return sc - s;
}
int main(int argc, char const *argv[])
{
int n;
char *s ="Hello Levi";
n = strlen(s);
printf("%d\n", n);
;
}
十、strchr
说明:
1、查找s中首次出现字符c位置
2、返回指针,指向c出现位置,否则返回NULL
代码:
#include <stdio.h>
char *strchr(const char *s, int c){
const char ch = c;
for(; *s != ch; ++s)
if(*s == '\0')
return NULL;
return (char *)s;
}
int main(int argc, char const *argv[])
{
char *s = "Golden Global View";
char *p;
p = strchr(s,'i');
if(p)
printf("%s\n", p);
else
printf("Not Found!\n");
;
}
十一、strcspn
说明:
1、在字符串s1中搜索s2出现的字符。
2、返回找到字符的下标值
代码:
#include <stdio.h>
size_t strcspn(const char *s1, const char *s2){
const char *sc1, *sc2;
for(sc1 = s1; *sc1 != '\0'; ++sc1)
for(sc2 = s2; *sc2 != '\0'; ++sc2)
if(*sc1 == *sc2)
return (sc1 - s1);
return (sc1 - s1);
}
int main(int argc, char const *argv[])
{
char *s="Golden Global View";
char *r="L";
int n = strcspn(s,r);
printf("%d\n", n);
;
}
十二、strrchr
说明:
1、在字符串搜索c字符
2、返回指针,指向搜索c字符最后出现的字符下标
代码:
#include <stdio.h>
char *strrchr(const char *s, int c){
const char ch = c;
const char *sc;
for(sc = NULL; ; ++s){
if(*s == ch)
sc = s;
if(*s == '\0')
return ((char *)sc);
}
}
int main(int argc, char const *argv[])
{
char *s = "Hello LLLLevi";
char *p = strrchr(s, 'L');
printf("%s\n", p);
;
}
十三、strstr
说明:
1、返回父串完全匹配子串的指针
2、返回的指针指向完全匹配子串的position
代码:
#include <stdio.h>
char *strchr(const char *s, int c){
const char ch = c;
for(; *s != ch; ++s)
if(*s == '\0')
return NULL;
return (char *)s;
}
char *strstr(const char *s1, const char *s2){
if(*s2 == '\0')
return ((char *)s1);
for(; (s1 = strchr(s1, *s2)) != NULL; ++s1){
const char *sc1, *sc2;
for(sc1 = s1, sc2 = s2; ; )
if(*++sc2 == '\0')
return ((char *)s1);
else if(*++sc1 != *sc2)
break;
}
return NULL;
}
int main(int argc, char const *argv[])
{
char *s = "ccdd View";
char *l = "dd";
char *p;
p=strstr(s,l);
if(p)
printf("%s\n", p);
else
printf("Not Found!");
;
}
Ps:深圳冬天还有蚊子,擦擦,蚊子太多了,不写了,回宿舍睡觉觉~~
“String.h” 源代码总结的更多相关文章
- C string.h 常用函数
参考:http://womendu.iteye.com/blog/1218155 http://blog.csdn.net/zccst/article/details/4294565 还有一些,忘记了 ...
- 字符串操作函数<string.h>相关函数strcpy,strcat,等源码。
首先说一下源码到底在哪里找. 我们在文件中包含<cstring>时,如果点击右键打开文档, 会打开cstring,我们会发现路径为: D:\Program Files\visual stu ...
- linux下错误的捕获:errno(errno.h)和strerror(string.h)的使用
参考:http://blog.csdn.net/starstar1992/article/details/52756387 linux下错误的捕获:errno和strerror的使用 经常在调用lin ...
- 《C标准库》——之<string.h>
<string.h>里的字符串操作函数是经常要用到的,因此阅读了源码后自己实现了一些: 拷贝函数 void * Mymemcpy(void * sDst, const void * sSr ...
- <string> 与<string.h>、<cstring>的区别
<string.h> <string.h>是C版本的头文件,包含比如strcpy.strcat之类的字符串处理函数. <cstring> 在C++标准化(1998年 ...
- 头文件 string.h cstring string 区别
1.#include <cstring> //不可以定义string s:可以用到strcpy等函数using namespace std; #include <stri ...
- C标准库<string.h>实现
本文地址:http://www.cnblogs.com/archimedes/p/c-library-string.html,转载请注明源地址. 1.背景知识 <string.h>中声明的 ...
- C/C++关于string.h头文件和string类
学习C语言时,用字符串的函数例如stpcpy().strcat().strcmp()等,要包含头文件string.h 学习C++后,C++有字符串的标准类string,string类也有很多方法,用s ...
- string.h文件中函数用法
下面为string.h文件中函数的详细用法: strcpy函数名:strcpy功 能: 拷贝一个字符串到另一个用 法: char *strcpy(char *destin, char *source) ...
随机推荐
- python 架构简介(转)
前言: 开发语言python 越来越火 ,作为开发比较火的语言,python 对网页等的支持也很好,当你想用python来写网页的时候你就要选择框架了.到底要选择呢什么样子的框架,最适合你的项目 ...
- OCP读书笔记(22) - 题库(ExamB)
101.Identify two situations in which you can use Data Recovery Advisor for recovery. (Choose two.) A ...
- asp.net学习之扩展GridView
原文:asp.net学习之扩展GridView 本节讨论如何从现有的控件,进而扩展成强大的,更定制的GridView控件 1.扩展BoundField 默认的BoundField不能显示多文本,文字一 ...
- Java 反射 想
所谓反射.是指在执行时状态中,获取类中的属性和方法.以及调用当中的方法的一种机制. 这样的机制的作用在于获取执行时才知道的类(Class)及当中的属性(Field).方法(Method)以及调用当中的 ...
- 【Python】Python的urllib模、urllib2模块的网络下载文件
因为需要从一些下载一个页PDF文件.但是需要下载PDF有数百个文件,这是不可能用人工点击下载.只是Python有相关模块,所以写一个程序PDF文件下载,顺便熟悉Python的urllib模块和ulrl ...
- EF中的transaction的使用范例
注意一点: 在EF中使用事物后,对于一个新增的model,在saveChanges后,可以得到该实体的自增ID,但在提交事物之前, 该数据并没有真正的新增到DB中,但此时可以得到model新增的自增I ...
- 第22章 职责链模式(Chain of Responsibility)
原文 第22章 职责链模式(Chain of Responsibility) 职责链模式 导读:职责链模式是一个既简单又复杂的设计模式,刚开始学习这个设计模式的时候光示例都看了好几遍.就为了理清里面的 ...
- java_maven_linux_windows下项目运行jar
我才用的是eclipse自带的export功能,暂时没把maven的打包插件研究清楚 导出jar包后,需要用解压缩打开,把配置文件copy到压缩包的内的顶级目录 保存 写 bat 脚本 @author ...
- 2014年辛星jquery解读第二节
*************jquery的语法****************** 1.jquery是通过选取HTML元素,而且对选取的元素运行某些操作,从而完毕某些特效的. 2.因此,我们在使用jQu ...
- HDU 3523 Image copy detection(KM最大匹配)
HDU 3523 Image copy detection 题目链接 题意:这题事实上题意读懂就简单了,说白了就是1-n放到1-n列,每列的值为每列上数字和该数字的差的绝对值,然后求总和最小 思路:就 ...