C/C++ 对常见字符串库函数的实现
在c中的string.h头文件中存在很多对字符串进行操作的函数,利用这些函数可以方便的对字符串进行操作。下面将对常见的字符串函数进行解释和实现。
strcpy
函数原型:char* _strcpy(char* dest,char* src)
函数功能:将str所指由nullptr的字符串复制到dst所指的数组中,并返回dest的指针。
函数说明:保证src和dest所指内存区域不能重叠且dest必须有足够的空间来容纳src的字符串。
函数实现
char* _strcpy(char* dest, const char* src)
{
assert(dest != nullptr&&src != nullptr);
//判断dest指针和src指针是否为空,若为空抛出异常
char* tmp = dest;
while (*tmp++ = *src++)
;
return dest;
}
strncpy
函数原型:char* _strncpy(char* dest,const char* src,size_t n)
函数功能:把src所指由nullptr结尾的字符串前n个字节复制到dest所指的数组中。
函数说明:如果src的前n个字节不含nullptr,则结果不会以nullptr结束;如果src的的长度小于n个字节,则以nullptr填充dest直到复制完n个字节;保证src和dest所指内存区域不能重叠且dest必须有足够的空间来容纳src的字符串。
函数实现:
char* _strncpy(char* dest, const char* src, int n)
{
assert(dest != nullptr&&src != nullptr);
//判断dest指针和src指针是否为空,若为空抛出异常
int i = 0;
char* tmp = dest;
while (i++ < n && (*tmp++ = *src++))
;
while (i++ < n)
*tmp++ = '\0';
return dest;
}
strcat
函数原型:char* _strcat(char *dest, const char *src)
函数功能:把src所指字符串添加到dest结尾处(覆盖dest结尾处的'\0')并添加'\0'。
函数说明:保证src和dest所指内存区域不能重叠且dest必须有足够的空间来容纳src的字符串。
函数实现:
char* _strcat(char* dest, const char* src)
{
assert(dest != nullptr&&src != nullptr);
//判断dest指针和src指针是否为空,若为空抛出异常
char* tmp = dest;
while (*tmp)//若为while(*dest++)则会跳过dest中的'\0'导致无法连接
tmp++;
while (*tmp++ = *src++)
;
return dest;
}
注意:使用时若实参dest的创建为char* dest=“abcd”,虽然可以编译通过,但运行时会引发中断,因为“abcd”为字符串常量,不可修改,可以使用char dest[n]="abcd"进行创建。
strncat
函数原型:char* _strncat(char* dest, const char* src,size_t n)
函数功能:把src所指字符串的前n个字符添加到dest结尾处(覆盖dest结尾处的'\0')并添加'\0'。
函数说明:保证src和dest所指内存区域不能重叠且dest必须有足够的空间来容纳src的字符串。
函数实现:
char* _strncat(char* dest, const char* src, size_t n)
{
assert(dest != nullptr&&src != nullptr);
//判断dest指针和src指针是否为空,若为空抛出异常
char* tmp = dest;
while (*tmp)//若为while(*dest++)则会跳过dest中的'\0'导致无法连接
tmp++;
while (n--)
{
if (!(*tmp++ = *src++))//保证当src的长度小于n时,此时tmp已有'\0'
return dest;
}
*tmp = '\0';//对于src长度大于n时,加上字符串结尾
return dest;
}
strlen
函数原型:size_t _strlen(const char* str)
函数功能:计算字符串str的长度。
函数说明:返回s的长度,不包括结束符NULL。
函数实现:
//常规写法
size_t _strlen(const char* str)
{
assert(str);
const char* eofStr = str;
while (*eofStr++)
;
return (eofStr - str - 1);
}
//递归写法,不借助变量(面试题要求)
size_t _strlen_R(const char* str)
{
/*if ('\0' == str)
return 0;
return _strlen_R(str + 1) + 1;*/
return *str ? _strlen_R(str + 1) + 1 : 0;//更为简洁
}
strcmp
函数原型:int _strcmp(const char* dest, const char* src)
函数功能:比较字符串dest和src。
函数说明:
当dest< src时,返回值 < 0
当dest= src时,返回值 = 0
当dest> src时,返回值 > 0
函数实现:
int _strcmp(const char* dest, const char* src)
{
assert(dest != nullptr&&src != nullptr);
//判断dest指针和src指针是否为空,若为空抛出异常
while (*dest&&*src && (*dest == *src))
{
dest++;
src++;
}
return (*dest - *src);
}
strncmp
函数原型:int _strncmp(const char* dest, const char* src, size_t n)
函数功能:比较字符串dest和src的前n个字符。
函数说明: 如果前n字节完全相等,返回值就为0;在前n字节比较过程中,如果出现dest[n]与src[n]不等,则返回(dest[n]-src[n])。
函数实现:
int _strncmp(const char* dest, const char* src, size_t n)
{
assert(dest != nullptr&&src != nullptr);
//判断dest指针和src指针是否为空,若为空抛出异常
if (!n)//若n为0,则返回0;
return 0;
while (n--&&*dest&&*src && (*dest == *src))
{
dest++;
src++;
}
return (*dest - *src);
}
strstr
函数原型:
函数功能:找出src字符串在dest字符串中第一次出现的位置(不包括src的'\0')
函数说明:返回该位置的指针,如找不到,返回空指针。
函数实现:
char* _strstr(const char* dest, const char* src)
{
assert(dest != nullptr);
//判断dest指针是否为空,若为空抛出异常
if (!src)
return (char*)dest;
while (*dest)
{
const char* destTmp = dest;
const char* srcTmp = src;
while (*srcTmp == *destTmp && (*srcTmp))//限时*srcTmp与*destTmp比较后相等至'\0'时继续访问出现越界
{
srcTmp++;
destTmp++;
}
if (!(*srcTmp))
return (char*)destTmp;
dest++;
}
return nullptr;
}
如有错误请指出,谢谢
C/C++ 对常见字符串库函数的实现的更多相关文章
- java常见字符串的操作
/** * java常见字符串的操作 */ public class Test7 { public static void main(String args[]){ StringBuffer sBuf ...
- Python 常见字符串常量和表达式
常见字符串常量和表达式 操作 解释 s = '' 空字符串 s = "spam's" 双引号和单引号相同 S = 's\np\ta\x00m' 转义序列 s = "&qu ...
- Python中常见字符串去除空格的方法总结
Python中常见字符串去除空格的方法总结 1:strip()方法,去除字符串开头或者结尾的空格>>> a = " a b c ">>> a.s ...
- C语言讲义——字符串库函数
字符串库函数<string.h> 求字符串长度(不含结束符'\0'****) strlen(str) 字符串赋值(可能造成数组越界) strcpy(str," 水浒传 " ...
- 5. 常见C语言字符串库函数的使用及实现
1. strncat 函数: [函数原型]#include <string.h> char *strncat( char *str1, const char *str2, size_t c ...
- c语言中几个常见的库函数strlen、strcmp、strcat、strcpy、strncpy、memset、memcpy、memmove、mmap
1.strlen() 1)计算给定字符串的长度,不包括’\0’在内 unsigned int strlen(const char *s) { assert(NULL != s);//如果条件不满足,则 ...
- c语言字符串库函数#include<string.h>
字符串函数<string.h> 在头文件<string.h>中定义了两组字符串函数.第一组函数的名字以str开头:第二组函数的名字以mem开头.只有函数memmove对重叠对象 ...
- mysql常见字符串处理函数结束
一.简明总结 ASCII(char) 返回字符的ASCII码值 BIT_LENGTH(str) 返回字符串的比特长度 CONCAT(s1,s2…,sn) 将s1,s2…,sn连接成字符串 CONCAT ...
- C语言字符串库函数的实现
1.strlen(字符串的长度) size_t Strlen(const char* str) { assert(str); ;; ++i) { if (str[i] == '\0') return ...
随机推荐
- Unity Shader : Ghost(残影) v1
前阵子组长给我提了个需求,要实现角色人物的残影.我百度google了一下,发现可以用两种方式实现这个效果:1.记录前几帧的人物位置,将其传入shader中,对每个位置进行一个pass渲染.2. 通过相 ...
- 将Excel中数据导入数据库(二)
在上篇文章中介绍到将Excel中数据导入到数据库中,但上篇文章例子只出现了nvachar类型,且数据量很小.今天碰到将Excel中数据导入数据库中的Excel有6419行,其中每行均有48个字段,有i ...
- 创建母版页导致js出现“ 'document.getElementById(...)' 为空或不是对象”错误
导读:一个控件在设计时的ID往往不同于生成页面后的ID,为了获得控件客户端ID,我们可以从生成的页面入手,冷静思考,把握主次,从底层框架入手 本文将为大家介绍一下 ASP.NET中在创建母版页时引来的 ...
- MSP430推荐网站
http://www.amobbs.com/thread-5092914-1-1.html http://www.amobbs.com/thread-4701106-1-1.html
- jQuery插件开发方式
一.jQuery扩展 1.$.extend(object) 类似于.Net的扩展方法,用于扩展jQuery.然后就可以用$.的方式调用. $(function(){ $.extend({ fun1: ...
- javascript 同步加载与异步加载
HTML 4.01 的script属性 charset: 可选.指定src引入代码的字符集,大多数浏览器忽略该值. defer: boolean, 可选.延迟脚本执行,相当于将script标签放入页面 ...
- QTP操作论坛回复编辑框----webelement
Set bp=browser("micclass:=browser","index:=0").page("micclass:=page") ...
- sql 截取字符串第一次出现字符之前的数据
截取sql 第一次出现字符之前的数据 (select left( a.ChangeProductName,charindex(',', ChangeProductName)-1)) as Chang ...
- Android SQLite数据储存方式
SQLiteOpenHelper 类 用SQLiteOpenHelper 类中的 getWritableDatabase()和getReadableDatabase()方法可以获得数据库的引用. 为了 ...
- 学习BFC
BFC全称是Block Formatting Context,即块格式化上下文.它是CSS2.1规范定义的,关于CSS渲染定位的一个概念.要明白BFC到底是什么,首先来看看什么是视觉格式化模型. 视觉 ...