模擬實現strlen的三種方法

来源:https://www.cnblogs.com/zzao/archive/2023/02/16/17128270.html
-Advertisement-
Play Games

一.併發和並行 多任務:一定時間段內,充分利用cpu資源,同時去執行多個任務 併發: 快速交替的 去執行多任務 並行: 真正同時的 去執行多任務 ,就是同時進行 二.多進程 1.多進程入門 知識點: 進程含義: 運行中的程式 進程特點: cpu資源分配的 最小單位 多進程模塊: multiproce ...


一、strlen()的工作原理

二、模擬實現strlen的三種方法

  1. 計數器方法
  2. 指針-指針
  3. 遞歸的方法

三、庫函數實現strlen的思路

四、庫函數的strlen同上面模擬實現strlen的區別

一、strlen工作原理

strlen函數工作原理:是計算字元串str的長度,直到空字元串結束,但不包含空字元串。(即該長度算至/0結束,但不包含/0)

通過以下代碼能有一個直觀的感受:

int main(){
  char arr[]="abcdef";
  int len=strlen(a);//"abcdef"即  'a' 'b' 'c' 'd' 'e' 'f' '\0'
                          //計算的是'\0'之前的元素個數
  printf("%d\n",len);     // 輸出結果為6
  return 0;  

}

以上則為strlen的工作原理

即strlen計算的是字元串內'\0'之前的元素個數。(不包含'\0')

二、模擬實現strlen的三種方法

  1. 計數器方法
  2. 指針-指針
  3. 遞歸的方法

我們通過上述得知strlen的工作原理,那麼我們接下來根據其工作原理實現strlen.
共有以下三種方式去實現:

ps:只有sizeof(數組名)&(數組名),此時代表的是整個數組的地址,其餘時候
數組名 僅僅代表首元素地址。在本文中,數組名 只代表首元素地址。

int my_strlen(){}    //要實現的功能,如下三種方式
int main(){
  char arr[]="abcdef";
  int len=my_strlen(a);                      
  printf("%d\n",len);     
  return 0;  

}

1.計數器方式(創建了臨時變數)

思路如下:將arr傳遞到my_strlen中,我們創建一個變數 count ,當 *arr!=0 時則 count +1, arr也+1 ,此時 *arr='b' ,arr和count再同時+1, 直到 *a=='\0'時,
我們返回 count 的值,此時的 count 的值為元素的個數。

圖解如下:

演算法如下:

int my_strlen(const char *str){
  int count=0;
  while(*str!='\0'){    //當為'\0'時,即while(0),條件為假,退出迴圈
    count++;
    str++;
}
  return count;
}

2.指針-指針(創建了臨時變數)

思路如下:創建指針p指向arr,當p!='\0'時,p加上1,直到p='\0',用
指針p-指針arr,此時的指針p代表的是'\0'的地址,指針arr代表的是首
元素地址,兩者相減得到的值為兩地址之間的元素個數。

圖解如下:

當p走到'\0'的地址時, p-arr=元素的個數

實現代碼如下:

 int my_strlen(const char*str){
   const char*p=str;

   while(*p){
     p++;
 }
   return p-str;
}

3.遞歸(不創建臨時變數)
思路如下:通過遞歸的思想。

圖解吐下:

ps:遞歸的基本思想是把一個大型複雜的問題層層轉化為一個與原問題相似的規
模較小的問題來求解。

演算法如下:

int my_strlen(const char*str){
    if(*str = = '\0'){
        return 0;
}
    else
        return 1+my_strlen(str+1)
}

三、參考庫函數如何實現strlen

對比自身用指針實現strlen,代碼更為簡潔,將 while(*p){p++;} 精簡為
while(*p++);

圖解如下:

ps:如何查看庫函數實現strlen。可看鏈接:如何查看庫函數實現的某些函數(strlen,strcmp,strcpy等)

四、庫函數的strlen同上面模擬實現strlen的區別

可通過如下代碼進行區別:

#include<string.h>
#include<stdio.h>
int main(){
    if(strlen("abc")-strlen("abcdef")>0)
    {printf("hehe\n");
        }
     else
        {printf("haha\n");
        }
}

很顯然,我們應該是列印 haha,但結果是hehe,為什麼列印的是hehe
因為在strlen()的函數聲明如下:size_t strlen(const char*str)

定義的類型是size_t,那麼size_t又是什麼類型
通過如下操作可知:

可知size_t是無符號整型,於是:無符號整型-無符號整型=無符號整型
於是列印的是hehe

我們模擬實現函數strlen返回的是int,於是當我們
調用my_strlen時,列印的便是haha,效果如下


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 組件設計是通過對功能及視覺表達中元素的拆解、歸納、重組,並基於可被覆用的目的,形成規範化的組件,通過多維度組合來構建整個設計方案,將這些組件整理在一起,便形成組件庫。本文我們主要講述基於Vant CLI的自建組件庫。Vant CLI 是一個基於 Vite 實現的 Vue 組件庫構建工具,通過 Van... ...
  • 進位之間的轉換 1.1 電腦硬體的基本認知 cpu: 中央處理器. 相當於人的大腦.運算中心,控制中心. 記憶體: 臨時存儲數據. 優點:讀取速度快。 缺點:容量小,造價高,斷電即消失. 硬碟: 長期存儲數據. 優點:容量大,造價相對低,斷電不消失。 缺點:讀取速度慢. 操作系統:統一管理電腦軟硬 ...
  • 前言 在app中經常會有發送公告的需求,告知用戶一些重大的事情。本文將使用FA重置版和qq收藏的筆記功能完成遠程公告的功能。 遠程公告的思路 在qq收藏新建筆記,設置好公告內容 分享筆記給好友,拿到外部鏈接地址 FA發送http請求,解析出公告內容 在qq收藏新建筆記,設置好公告內容 點擊頭像,在點 ...
  • JOSN處理和HttpMessageConverter 1.JSON處理-@ResponseBody 說明:在實際開發中,我們往往需要伺服器返回的數據都是 JSON 格式。 SpringMVC 提供了 @ResponseBody 註解,用來標註 Controller 方法的返回的格式為 JSON,將 ...
  • 時間輪工作原理解析 一.時間輪介紹 1.時間輪的簡單介紹 時間輪(TimeWheel)作為一種高效率的計時器實現方案,在1987年發表的論文Hashed and Hierarchical Timing Wheels中被首次提出。 其被髮明的主要目的在於解決當時操作系統的計時器功能實現中,維護一個定時 ...
  • 前言 對中文標題使用餘弦相似度演算法和編輯距離相似度分析進行相似度分析。 準備數據集part1 本次使用的數據集來源於前幾年的碩士學位論文,可根據實際需要更換。結構如下所示: 學位論文題名 基於捲積神經網路的人臉識別研究 P2P流媒體視頻點播系統設計和研究 校園網安全體系的設計與實現 無線感測器網路中 ...
  • 介紹 vector(矢量; 向量),vector是C++標準模板庫(STL)中的部分內容,中文偶爾譯作“容器”,但並不准確。它是一個多功能的,能夠操作多種數據結構和演算法的模板類和函數庫。vector之所以被認為是一個容器,是因為它能夠像容器一樣存放各種類型的對象,簡單地說,vector是一個能夠存放 ...
  • 目錄: finally的使用 finally面試題 final、finally、finalize的區別 finally子句的使用: 1、在finally子句中的代碼是最後且一定會執行的,即使try語句塊中的代碼出現異常 2、finally子句必須和try一起出現,不能單獨編寫 3、finally子句 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...