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 ...
随机推荐
- VS集成Qt环境搭建
环境:VS2010 + Qt5.2 关于VS的下载.安装,这里就不再做过多阐述. 一.下载Qt5.2安装包(qt-windows-opensource)与Qt插件(Visual Studio Add- ...
- cygwin中运行命令提示command not found的解决方法
在cygwin下运行ls等linux常见命令时出现“command not found”的提示,原因是环境变量没有配置好,因此只要将环境变量配置正确,即可正常使用.举例说明,cygwin安装在C盘根目 ...
- 写给自己的Java程序员学习路线图
恩,做开发的工作已经三年多了,说起来实在是惭愧,自己的知识树还像一棵小草一样,工作中使用到了许多的知识和技术,不过系统性不够.根基不牢.并且不够深入!当然,慢慢的我也更加的清楚,我需要学习一些什么样的 ...
- OpenJudge 核电站
描述 一个核电站有N个放核物质的坑,坑排列在一条直线上.如果连续M个坑中放入核物质,则会发生爆炸,于是,在某些坑中可能不放核物质. 任务:对于给定的N和M,求不发生爆炸的放置核物质的方案总数 输入 只 ...
- 洛谷P1467 循环数 Runaround Numbers
P1467 循环数 Runaround Numbers 89通过 233提交 题目提供者该用户不存在 标签USACO 难度普及/提高- 提交 讨论 题解 最新讨论 暂时没有讨论 题目描述 循环数是 ...
- ios7 导航栏 手势 右划 自动返回 相关
http://www.tuicool.com/articles/vMfAVv 纪录一下,
- Linux选型:开源不是免费 首选红帽和SUSE
首发:http://tech.it168.com/a2014/0324/1606/000001606245.shtml 企业级服务器系统选型报告:http://www.it168.com/redian ...
- STM32F05 学习中............
今天,拿到stm32f05的板子已经三个月了吧,但是没有真的研究过,真的对板子过意不去了...所以决定今天好好的对待我的板子.
- oracle11g空表不能导出记录
select 'alter table '||table_name||' allocate extent(size 64k);' from tabs t where not exists (selec ...
- 复杂的sql 一对多查询
SELECT distinct u.Name as UserName, a.OrderId, ( select d.SignCity from T_O ...