#include <cassert>
#include <iostream>
using namespace std; /*
strlen 返回字符串不包含结束符\0的长度
*/
int mystrlen(const char *str)
{//非递归strlen
assert(str);//必须不为空
int len = ;
while (*str++)
len++;
return len;
}
int mystrlen1(const char *str)
{//递归 stelen
if (*str == '\0') return ;
return mystrlen1(str + ) + ;
}
/*
strcmp,如果str1大,返回正数,小返回负数,相等返回0
ascii码共128种(0-127),所以可以转为unsigned char(范围-128到127)
且无符号两数相等情况下相减必为0,而有符号相减为0,两数的每一位不一定相等
*/
int mystrcmp(const char* str1,const char* str2)
{
assert(str1 && str2);//允许一个为空
int ret = ;
while (!(ret = *(unsigned char*)str1 - *(unsigned char*)str2) && *str1)//注意*str1放后面,前面肯定计算完毕
{//结束符ascii码是0。相等进入while,不相等则ret存储差值,如果str1短,已经是负值,长则为正值
str1++;
str2++;
}
if (ret > ) return ;
else if(ret < ) return ;
else return ;
} /*
strcat 返回新dst。将字符串src包括结束符都复制到dst后,注意覆盖dst的\0
不考虑dst不够存放src的情况(会报错,但没法处理,因为dst为指针,不知其空间大小
*/
char *mystrcat(char *dst,const char *src)
{
assert(dst && src);//允许一个为空
char *tmp = dst;
while (*tmp) tmp++;//指到dst的结束符处(比strcpy多了这一步
while (*src)
*tmp++ = *src++;
*tmp = *src;//复制结束符
return dst;
} /*
strcpy 返回新dst,将字符串src包括结束符全部复制到dst开始处
不考虑dst不够存放src,容易溢出
*/
char *mystrcpy(char *dst, const char *src)
{
assert(dst && src);
char *tmp = dst;
while (*src)
*tmp++ = *src++;
*tmp = *src;
return dst;
}
/*
memmove size指定复制长度,如果源在前且与目标有重叠,则逆向复制
而memcpy都是正向复制
*/
void *mymemmove(void *dst, void *src, size_t size)
{
if (dst == nullptr || src == nullptr) return nullptr;
void *res = dst;
char *pdst = (char *)dst;
char *psrc = (char *)src;
if (pdst >= psrc && pdst <= psrc + size)
{
for (int i = size - ; i >= ; i--)
*(pdst + i) = *(psrc + i);//源在前,逆向复制
}
else
{
for (int i = ; i < size; i++)
*(pdst + i) = *(psrc + i);//源在后/不重叠,正向复制
}
return dst;
} int main()
{
char str[] = {'','',''};
const char *a = ""; //cout << mystrlen(a) << endl;
//cout << mystrcmp("2222", "22") << endl;
char dst[] = "";
cout << mystrcat(dst, "") << endl;
cout << mystrcpy(dst, "") << endl;
}

strlen、strcmp、strcat、strlen、memmove的更多相关文章

  1. 不使用库函数、自己编写的(strlen、strcpy、strcmp、strcat、memcmp、memcpy、memmove)

    不使用库函数.自己编写的(strlen.strcpy.strcmp.strcat.memcmp.memcpy.memmove) //求字符串长度的函数 int my_strlen(const char ...

  2. strcpy、strncpy、strlen、memcpy、memset、strcat、strncat、strcmp、strncmp,strchr

    1.strcpy #include<stdio.h> #include<assert.h> char *mystrcpy(char *dest, const char *src ...

  3. Linux C 字符串函数 strlen()、strcat()、strncat()、strcmp()、strncmp()、strcpy()、strncpy() 详解

      strlen(返回字符串长度) 表头文件 #include <string.h> 定义函数 size_t strlen(const char *s); 函数说明 strlen()用来计 ...

  4. 常见函数strlen、strcmp、strstr原型实现

    数组元素的结束符为'\0'.串的结束符为NULL 一.strlen #include <iostream> using namespace std; long h_strlen(const ...

  5. 转:C语言字符串操作函数 - strcpy、strcmp、strcat、反转、回文

    转自:C语言字符串操作函数 - strcpy.strcmp.strcat.反转.回文 C++常用库函数atoi,itoa,strcpy,strcmp的实现 作者:jcsu C语言字符串操作函数 1. ...

  6. C语言字符串操作函数 - strcpy、strcmp、strcat、反转、回文

    原文:http://www.cnblogs.com/JCSU/articles/1305401.html C语言字符串操作函数 1. 字符串反转 - strRev2. 字符串复制 - strcpy3. ...

  7. 码海拾遗:strstr()、strcmp()和strcpy()实现

    1.strstr()实现 原型:char * strstr(const char * str1, const char * str2) 说明:判断str2是否为str1的子串,如果是则返回str2第一 ...

  8. 逆向 string.h 函数库 memset、strcpy、strcmp 函数

    memset 函数 函数原型:void *memset(void *str, int c, size_t n) 主要功能:复制字符 c(一个无符号字符)到参数 str 所指向的字符串的前 n 个字符 ...

  9. c语言求平面上2个坐标点的直线距离、求俩坐标直线距离作为半径的圆的面积、递归、菲波那次数列、explode

    #include <stdio.h> #include <math.h> #include <string.h> char explode( char * str ...

  10. 深入理解类成员函数的调用规则(理解成员函数的内存为什么不会反映在sizeof运算符上、类的静态绑定与动态绑定、虚函数表)

    本文转载自:http://blog.51cto.com/9291927/2148695 总结: 一.成员函数的内存为什么不会反映在sizeof运算符上?             成员函数可以被看作是类 ...

随机推荐

  1. LINUX shell脚本相关

    调试脚本 测试脚本语法:bash -n file.sh 查看脚本每一步执行情况:bash -x file.sh   位置变量:$1,$2,... 特殊变量:           %?:最后一个命令的执 ...

  2. pip install 报SSL异常和timeout异常

    在安装pip3 install virtualenv时报了SSL异常 如图 pip is configured with locations that require TLS/SSL, however ...

  3. 显示等待WebDriverWait+lambda

    代码,关键代码标红 参考文章:https://www.cnblogs.com/yoyoketang/p/6517477.html #coding:utf-8 ''' 这里写了一个百度搜索页的pageo ...

  4. 把 MongoDB 当成是纯内存数据库来使用(Redis 风格)

    基本思想 将MongoDB用作内存数据库(in-memory database),也即,根本就不让MongoDB把数据保存到磁盘中的这种用法,引起了越来越多的人的兴趣.这种用法对于以下应用场合来讲,超 ...

  5. Java + selenium 元素定位(1)之By id/Name/ClassName

    这篇文章开始,要介绍web自动化核心的内容,也是最困难的部分了,就是定位元素,并去对元素进行操作.想要对元素进行操作,第一步,也是最重要的一步,就是要找到这个元素,如果连元素都定位不到,后续什么操作都 ...

  6. python类与对象

    1.  class命名规范:首字母大写,驼峰命名法 2.  class 里面函数括号里面带(self)说明这是一个实例,调用实例方法需要用实例调用 class Teacher: def  test_1 ...

  7. 50-python基础-python3-列表-函数sorted() 对列表进行临时排序

    sorted()函数对列表进行临时排序,返回排序后的列表: 区别列表方法sort()原地修改,无返回值. 1-要保留列表元素原来的排列顺序,同时以特定的顺序呈现它们,可使用函数sorted() . 2 ...

  8. CTU Open 2018 Lighting /// 组合数递推 二进制

    题目大意: 给定n k 给定一个数的二进制位a[] 求这个数加上 另一个二进制位<=n的数b 后 能得到多少个不同的 二进制位有k个1 的数 样例 input10 51000100111 out ...

  9. Vue-基础(二)

    一,Vue中的组件化开发: Vue中的组件也就是Vue实例 组件类型: 通用组件(例如,表单,弹窗,布局类等) 业务组件(抽奖,机器分类) 页面组件(单页面开发程序的每个页面都是一个组件) 组件开发三 ...

  10. 如何减少代码中的if-else嵌套

    实际项目中,往往有大量的if-else语句进行各种逻辑校验,参数校验等等,大量的if-else,语句使代码变得臃肿且不好维护,本篇文章结合我自己的经验,就减少if-else语句给出以下几种方案,分别适 ...