cstring头文件函数解析
原创作品,转载请注明来源:http://www.cnblogs.com/shrimp-can/p/5643829.html
在使用由字符数组或指针组成的字符串的时候,要用到一些函数,这些函数通常包含在头文件ctring中,以下是这个头文件中的函数的解析。
一、拷贝相关函数:
memcpy:void* memcpy(void* destination,const void* source, size_t num)
从source指向的地址拷贝num bytes到destination指向的地址。不检查source中的空字符,总是拷贝num bytes,可能产生溢出,当destination和source的大小小于num时。
memmove:void* memmove(void* destination,const void* source, size_t num)
从source指向的地址拷贝num bytes到destination指向的地址。常用于同一字符串的改变。不检查source中的空字符,总是拷贝num bytes,可能产生溢出,当destination和source的大小小于num时。
char str[] = "memmove can be very useful......";
memmove (str+20,str+15,11);
puts(str);
输出为:memmove can be very very useful.
strcpy:char * strcpy ( char * destination, const char * source )
将source指向的字符串拷贝到destination指向的地方。会检查空字符,遇空字符停止(字符串结束标志)。可能存在溢出。
strncpy:char * strncpy ( char * destination, const char * source, size_t num )
将source指向的字符串拷贝到destination指向的地方,最多拷贝num bytes,或者遇到空字符(字符串结束标志)停止。num可以防止溢出。
二、连接相关函数:
strcat:char * strcat ( char * destination, const char * source )
将source指向的字符串连接到destination指向的字符串的后面。可能存在溢出,当连接后的大小大于destination的大小。
char str[80];
strcpy (str,"these ");
strcat (str,"strings ");
strcat (str,"are ");
strcat (str,"concatenated.");
puts (str);
输出为:these strings are concatenated.
strncat:char * strncat ( char * destination, const char * source, size_t num )
将source指向的字符串连接到destination指向的字符串的后面。最多连接num bytes。
三、比较相关函数:
memcmp:int memcmp ( const void * ptr1, const void * ptr2, size_t num )
比较ptr1、ptr2指向的内存块的前面num bytes,如果都相同则返回0,如果第一个不同byte ptr1的小于ptr2的,返回负数,否则返回正数。如果前面都相同,即使中间遇到空字符,也会继续比较下去,直到比较完所有的num bytes。
char buffer1[] = "DWgaOtP12df0";
char buffer2[] = "DWGAOTP12DF0";
int n;
n=memcmp ( buffer1, buffer2, sizeof(buffer1) );
if (n>0) printf ("'%s' is greater than '%s'.\n",buffer1,buffer2);
else if (n<0) printf ("'%s' is less than '%s'.\n",buffer1,buffer2);
else printf ("'%s' is the same as '%s'.\n",buffer1,buffer2);
输出为:'DWgaOtP12df0' is greater than 'DWGAOTP12DF0'.
strcmp:int strcmp ( const char * str1, const char * str2 );
比较str1、str2指向的字符串,直到遇到不相同的字符或者空字符结束。如果都相同则返回0,如果第一个不同byte ptr1的小于ptr2的,返回负数,否则返回正数。
strncmp:int strncmp ( const char * str1, const char * str2, size_t num )
比较ptr1、ptr2指向的字符串,直到遇到不相同的字符或者空字符结束或者比较完前面的num bytes结束。如果都相同则返回0,如果第一个不同byte ptr1的小于ptr2的,返回负数,否则返回正数。
strcoll:int strcoll ( const char * str1, const char * str2 )
比较str1、str2指向的字符串,直到遇到不相同的字符或者空字符结束。如果都相同则返回0,如果第一个不同byte ptr1的小于ptr2的,返回负数,否则返回正数。函数的行为决定于所选择的c语言环境中的LC_CALLATE类别(用的比较少)
strxfrm:size_t strxfrm ( char * destination, const char * source, size_t num )
传输source指向的字符串到当前环境,然后拷贝前面num bytes字符到destination指向的地方,返回传输的字符串的长度,不包含空字符。函数的行为决定于所选择的c语言环境中的LC_CALLATE类别(用的比较少)
四、检索相关函数:
memchr:const void * memchr ( const void * ptr, int value, size_t num );
void * memchr ( void * ptr, int value, size_t num );
在ptr指向的内存中的前num bytes中搜索值value,返回第一个value的指针,如果没有找到返回空指针。
char * pch;
char str[] = "Example string";
pch = (char*) memchr (str, 'p', strlen(str));
if (pch!=NULL)
printf ("'p' found at position %d.\n", pch-str+1);
else
printf ("'p' not found.\n");
输出:'p' found at position 5.
strchr:const char * strchr ( const char * str, int character );
char * strchr ( char * str, int character );
在ptr指向的字符串中搜索值value,返回第一个value的指针,如果没有找到返回空指针。
strcspn:size_t strcspn ( const char * str1, const char * str2 );
在str1指向的字符串中搜索str2指向的字符串中的任意一个字符,返回找到的第一个字符前面的字符数,如果没有找到返回str1指向的字符串的字符数。
char str[] = "fcba73";
char keys[] = "1234567890";
int i;
i = strcspn (str,keys);
printf ("The first number in str is at position %d.\n",i+1);
输出:The first number in str is at position 5
strpbrk:const char * strpbrk ( const char * str1, const char * str2 );
char * strpbrk ( char * str1, const char * str2 );
在str1指向的字符串中搜索str2指向的字符串中的任意一个字符,返回找到的第一个字符的指针,如果没有找到返回空指针。
char str[] = "This is a sample string";
char key[] = "aeiou";
char * pch;
printf ("Vowels in '%s': ",str);
pch = strpbrk (str, key);
while (pch != NULL)
{
printf ("%c " , *pch);
pch = strpbrk (pch+1,key);
}
输出:Vowels in 'This is a sample string': i i a a e i
strrchr:const char * strrchr ( const char * str, int character );
char * strrchr ( char * str, int character );
在ptr指向的字符串中搜索值character,返回最后一个character的指针,如果没有找到返回字符串结束处的指针。
strspn:size_t strspn ( const char * str1, const char * str2 );
在str1指向的字符串中搜索str2指向的字符串中的任意字符,返回找到的字符个数。不包含空字符。
char strtext[] = "129th";
char cset[] = "1234567890";
i = strspn (strtext,cset);
printf ("The initial number has %d digits.\n",i);
输出:The initial number has 3 digits.
strstr:const char * strstr ( const char * str1, const char * str2 );
char * strstr ( char * str1, const char * str2 );
在str1指向的字符串中查找str2指向的字符串,返回找到的第一次出现位置的指针,若没找到,返回空指针。
strtok:char * strtok ( char * str, const char * delimiters );
将str指向的字符串进行划分,delimiters指向的字符串的任意字符都是一个分割点。第一次调用,起始位置为字符串的开始,后面的调用,用NULL指针来替代str,代表从上一次分割处开始。如果找到分割点,返回起始位置的指针,否则返回空指针。
char str[] ="- This, a sample string.";
char * pch;
printf ("Splitting string \"%s\" into tokens:\n",str);
pch = strtok (str," ,.-");
while (pch != NULL)
{
printf ("%s\n",pch);
pch = strtok (NULL, " ,.-");
}
输出:
Splitting string "- This, a sample string." into tokens:
This
a
sample
string
五、其他函数
memset:void * memset ( void * ptr, int value, size_t num );
设置ptr指向的内存的前面num bytes的值为value
char str[] = "almost every programmer should know memset!";
memset (str,'-',6);
puts (str);
输出:------ every programmer should know memset!
strerror:char * strerror ( int errnum );
将参数设置为erro,将返回描述错误的字符串
FILE * pFile;
pFile = fopen ("unexist.ent","r");
if (pFile == NULL)
printf ("Error opening file unexist.ent: %s\n",strerror(errno));
输出:Error opening file unexist.ent: No such file or directory
strlen:size_t strlen ( const char * str );
返回str指向字符串的长度,不包含空字符
参考文献:http://www.cplusplus.com/reference/cstring/
cstring头文件函数解析的更多相关文章
- xe7 c++builder 日期时间头文件函数大全 date
c++builde r时间日期函数大全,在头文件System.DateUtils.hpp,不过没有IncMonth,因为这个函数定义在System.SysUtils.hpp里头了,唉 date,dat ...
- linux c 获取头文件函数getenv
#include <stdio.h>#include <stdlib.h> int main(){ printf("%s\n", getenv(" ...
- wordpress模板各文件函数解析
修改主题时发现好多WordPress主题函数都不了解,因此网上摘抄了一份放在自己博客上,便于以后好找. 在WordPress中如何按你的意愿显示页面,关键看你是否了解WordPress主题模板页面.这 ...
- APP安全之代码混淆防止反编译查看真实的头文件函数声明
现在有的公司对自己的爱屁屁(APP)安全上有重视,所以本篇讲一下代码混淆,即使别人反编译出来,也看不出来头文件的信息. 上菜: 1.首先安装class-dump,下载地址:http://steveny ...
- 头文件 string.h cstring string 区别
1.#include <cstring> //不可以定义string s:可以用到strcpy等函数using namespace std; #include <stri ...
- C++解析头文件-Qt自动生成信号声明
目录 一.瞎白话 二.背景 三.思路分析 四.代码讲解 1.类图 2.内存结构声明 3.QtHeaderDescription 4.私有函数讲解 五.分析结果 六.下载 一.瞎白话 时间过的ZTMK, ...
- .h头文件、 .lib库文件、 .dll动态链接库文件之间的关系
转自.h头文件. .lib库文件. .dll动态链接库文件之间的关系 h头文件作用:声明函数接口 dll动态链接库作用:含有函数的可执行代码 lib库有两种: (1)静态链接库(Static Liba ...
- .h头文件 .lib库文件 .dll动态库文件之间的关系
.h头文件是编译时必须的,lib是链接时需要的,dll是运行时需要的. 附加依赖项的是.lib不是.dll,若生成了DLL,则肯定也生成 LIB文件.如果要完成源代码的编译和链接,有头文件和lib就够 ...
- .h(头文件) .lib(库文件) .dll(动态链接库文件) 之间的关系和作用的区分
.h头文件是编译时必须的,lib是链接时需要的,dll是运行时需要的.附加依赖项的是.lib不是.dll,若生成了DLL,则肯定也生成 LIB文件.如果要完成源代码的编译和链接,有头文件和lib就够了 ...
随机推荐
- view里面的tableview顶部被view的导航栏盖住了的问题
在你要显示的控制器的viewDidLoad中添加代码 self.edgesForExtendedLayout = UIRectEdgeNone; 另外记住tableView要遵循代理cell才能显示. ...
- github在windows下的安装和基本使用
1.在win下安装github时花费的时间是非常长的,有时还会出现因各种原因安装不成功.离线包本地安装方便的解决了此问题.点击http://pan.baidu.com/s/1boGrNLP可下载,解压 ...
- Struts系列笔记(6)---action接收请求参数
action接收请求参数 在web开发中,去接收请求参数来获得表单信息非常的常见,自己也总结整理了有关Struts2通过action接收请求参数的几种方法. Struts2 提供三种数据封装的方式: ...
- spring+struts2+ibatis 框架整合以及解析
一. spring+struts2+ibatis 框架 搭建教程 参考:http://biancheng.dnbcw.net/linux/394565.html 二.分层 1.dao: 数据访问层(增 ...
- Spring Mvc中使用Task实现定时任务,以及遇到的一个问题
Spring中实现定时任务其实很简单,可以使用spring中自带的task 相当于轻量级的Quartz,并且spring 3.0 之后支持注解的方式,使用起来非常简单,方便,具体实现如下: 第一步,修 ...
- JavaScript 基本类型值-String类型
▓▓▓▓▓▓ 大致介绍 String类型用于表示由零或多个16位Unicode字符组成的字符序列,即字符串.在JavaScript中没有单个的字符型,都是字符串.字符型就相当于只包含一个字符的字符串. ...
- WebApi接口传参不再困惑:传参详解
原文出处: 懒得安分 前言:还记得刚使用WebApi那会儿,被它的传参机制折腾了好久,查阅了半天资料.如今,使用WebApi也有段时间了,今天就记录下API接口传参的一些方式方法,算是一个笔记,也希望 ...
- Linux i2c子系统(三) _解决probe无法执行
如果你也遇到了填充了id_match_table,compitible怎么看都一样,但probe就是不执行(让我哭一会),你可以回头看一下上一篇的模板,我们这里虽然使用的是设备树匹配,但和platfo ...
- 关于Xmanager使用问题的总结
做大数据的人对Xmanager这类远程连接工具应该都不陌生,我在使用Xmanager时遇到了一些问题并经过google和亲测解决,写在这里与大家分享. 1. [问题描述] 在windows上使用Xma ...
- win7下使用git
1 安装git for window 2 安装tortoiseGit 3 生成public key 3.1 打开git bash 3.2 创建~/.ssh文件夹 mkdir ~/.ssh 3.3 配置 ...