C语言——oj刷题——模拟实现库函数strlen

目录

方法一:迭代法

方法二:递归法

方法三:指针算术法

方法四:汇编指令法


当我们使用C语言进行字符串操作时,经常会用到库函数strlen来获取字符串的长度。strlen函数的作用是计算一个以null字符结尾的字符串的长度。在本篇博客中,我将详细介绍如何模拟实现strlen函数的几种方法。


方法一:迭代法

迭代法是最简单和直观的方法,它通过遍历字符串中的字符,直到遇到null字符为止,然后返回遍历的字符数作为字符串的长度。

size_t strlen_iterative(const char* str) {size_t len = 0;while (*str != '\0') {len++;str++;}return len;
}

方法二:递归法

递归法是一种更为复杂的方法,它通过递归调用自身来计算字符串的长度。递归的终止条件是遇到null字符,返回0,否则返回递归调用加1。

size_t strlen_recursive(const char* str) {if (*str == '\0') {return 0;}return strlen_recursive(str + 1) + 1;
}

方法三:指针算术法

指针算术法是一种更为高效的方法,它利用指针的算术运算来计算字符串的长度。该方法使用两个指针,一个指向字符串的起始位置,另一个指向字符串的结束位置,然后通过两个指针相减得到长度。

size_t strlen_pointer_arithmetic(const char* str) {const char* end = str;while (*end != '\0') {end++;}return (size_t)(end - str);
}

方法四:汇编指令法

汇编指令法是一种最底层的方法,它直接使用汇编指令来计算字符串的长度。这种方法需要了解汇编语言的基础知识,并且在不同的平台上可能会有所不同。

size_t strlen_assembly(const char* str) {size_t len;__asm__("xor %0, %0\n""1:\n""cmpb $0, (%1)\n""je 2f\n""inc %0\n""inc %1\n""jmp 1b\n""2:\n": "=r"(len): "r"(str): "cc", "memory");return len;
}
这些方法都可以模拟实现strlen函数,你可以根据自己的需求选择其中之一。希望这篇博客对你理解字符串长度的计算过程有所帮助。如果你对其中的任何方法有疑问,或者需要更多的解释和示例,请随时告诉我。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/679714.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

六、java高级-泛型(一)

六、泛型 1、泛型 从什么是泛型、泛型从何而来、泛型出现是为了解决什么问题、功能及作用说泛型 1.1什么是泛型? 泛型:即“参数化类型”,也就是将需要操作对象的类型进行参数化。在编写代码的时候,不必声明操作对象(…

docker从入门到入土

docker到底是什么? docker是世界领先的软件容器平台,基于GO语言进行开发实现docker能够自动执行重复性任务,例如搭建和配置开发环境,从而解放开发人员用户可以方便地创建和使用容器,把自己的应用放入容器,…

基于Robei EDA--实现串口通信

一、串口简介 串口作为常用的三大低速总线(UART、SPI、IIC)之一,在设计众多通信接口和调试时占有重要地位。但UART和SPI、IIC不同的是,它是异步通信接口,异步通信中的接收方并不知道数据什么时候会到达,所…

int VS Integer

在Java中,int 是一种基本数据类型(primitive type),而 Integer 是 int 的包装类(wrapper class)。它们之间的主要区别在于以下几点: 数据类型:int 是基本的整数类型,它在…

Linux gzip命令教程:如何有效地压缩和解压文件(附实例详解和注意事项)

Linux gzip命令介绍 gzip(GNU zip)是一种在Linux系统中常见的命令行压缩工具。它使用DEFLATE压缩算法来减小文件的大小,使文件更易于存储和传输。gzip主要用于压缩文本文件、Tar归档文件和网页。不建议使用gzip来压缩图像、音频、PDF文档和其…

【P1506 拯救oibh总部】

拯救oibh总部 题目背景 oibh 总部突然被水淹没了!现在需要你的救援…… 题目描述 oibh 被突来的洪水淹没了,还好 oibh 总部有在某些重要的地方起一些围墙。用 * 号表示,而一个四面被围墙围住的区域洪水是进不去的。 oibh 总部内部也有许…

【后端高频面试题--SpringBoot篇】

🚀 作者 :“码上有前” 🚀 文章简介 :后端高频面试题 🚀 欢迎小伙伴们 点赞👍、收藏⭐、留言💬 这里写目录标题 1.什么是SpringBoot?它的主要特点是什么?2.列举一些Spri…

《CSS 简易速速上手小册》第4章:视觉美学(2024 最新版)

文章目录 4.1 颜色理论在 CSS 设计中的应用:网页的调色盘4.1.1 基础知识4.1.2 重点案例:创建一个具有情感设计的登录页面4.1.3 拓展案例 1:使用颜色增强信息的可视化表示4.1.4 拓展案例 2:利用颜色创建网站的品牌身份 4.2 字体与文…

JS逆向手记01__前端基础

系列文章目录 系列手记占位 文章目录 系列文章目录前言一、js自执行函数语法二、js变量类型的转换(与字符串相加)三、浏览器环境(BOM)四、html渲染环境(DOM)五、html发起请求(表单form&#xf…

书生·浦语大模型第四课作业

基础作业: 构建数据集,使用 XTuner 微调 InternLM-Chat-7B 模型, 让模型学习到它是你的智能小助手,效果如下图所示,本作业训练出来的模型的输出需要将不要葱姜蒜大佬替换成自己名字或昵称! 1.安装 # 如果你是在 Int…

Java是如何实现的平台无关?

🎬作者简介:大家好,我是小徐🥇☁️博客首页:CSDN主页小徐的博客🌄每日一句:好学而不勤非真好学者 📜 欢迎大家关注! ❤️ 1、什么是平台无关性 平台无关性就是一种语言在…

寒假作业

手写盗版微信登入界面 #include "mainwindow.h" #include "ui_mainwindow.h"MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow) {ui->setupUi(this);this->resize(421,575);this->setFixedSize(421,575);th…

C#系列-C#EF框架实现雪花主键(20)

在C#中,使用Entity Framework (EF) 框架并不直接涉及到主键的生成策略。主键的生成通常是在数据库层面或者在应用程序层面处理的。雪花主键(Snowflake ID)是一种在分布式系统中生成唯一ID的算法,它通常是由Twitter的雪花算法演变而…

接口测试框架分析

框架大体上已经写完了,不过说实话好多代码让我自己写我也写不出来,那该怎么办呢?很简单,把现在已经写好的代码保存起来,等用的时候拿出来复制粘贴就好了,如果你是大神,自己会写,那就…

TikTok:短视频时代的崛起

导言: TikTok,作为一款全球短视频社交应用,正风靡全球,引领着数字娱乐的新潮流。其简洁的用户界面、创意无限的短视频内容,以及强大的社交互动功能,使其成为全球数以亿计的用户喜爱的平台。 TikTok的特点&a…

H5 红色文字抖动网址发布页/引导页源码

H5 红色文字抖动网址发布页/引导页源码 源码介绍:一款红色文字抖动网页源码,可用于引导页或网址发布页。 下载地址: https://www.changyouzuhao.cn/10470.html

第9讲用户信息修改实现

用户信息修改实现 后端修改用户昵称: /*** 更新用户昵称* param wxUserInfo* param token* return*/ RequestMapping("/updateNickName") public R updateNickName(RequestBody WxUserInfo wxUserInfo,RequestHeader String token){if(StringUtil.isNot…

在JavaScript或TypeScript中,@符号的用法

在JavaScript或TypeScript中,符号在导入语句中用作包名的一部分,表示该包是一个命名空间包(Namespace package)或作用域包(Scoped package)。这种命名方式主要用于组织和管理由同一组织或个人发布的相关包。…

MySQL篇----第二十二篇

系列文章目录 文章目录 系列文章目录前言一、什么是表级锁二、什么是页级锁三、什么是行级锁四、什么是悲观锁前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给你的码吧。 一、…

selenium 驱动 Edge浏览器,解决selenium打开Edge浏览器闪退问题

一、Edge浏览器驱动下载 1、在设置中查看浏览器的版本号 2、在官网中进行对应下载 Microsoft Edge WebDriver - Microsoft Edge Developer 二、环境变量配置 1、打开设置界面 右击【此电脑】---选择【属性】----选择【高级系统设置】-----点击【环境变量】 2、变量设置 在…