欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言實(shí)例問題探究字符串函數(shù)的應(yīng)用

 更新時(shí)間:2022年04月18日 16:01:37   作者:清風(fēng)自在 流水潺潺  
字符串函數(shù)(String processing function)也叫字符串處理函數(shù),指的是編程語(yǔ)言中用來(lái)進(jìn)行字符串處理的函數(shù),如C,pascal,Visual以及LotusScript中進(jìn)行字符串拷貝,計(jì)算長(zhǎng)度,字符查找等的函數(shù)

一、典型問題一

下面的程序輸出什么?為什么?

分析

snprintf 函數(shù)本身是可變參數(shù)函數(shù),原型如下:int snprintf( char* buffer, int buf_size, const char*fomart,... )

當(dāng)函數(shù)只有 3 個(gè)參數(shù)時(shí),如果第三個(gè)參數(shù)沒有包含格式化信息,函數(shù)調(diào)用沒有問題:相反,如果第三個(gè)參數(shù)包含了格式化信息,但缺少后續(xù)對(duì)應(yīng)參數(shù),則程序行為不確定。

下面編程看看究竟會(huì)輸出什么:

#include <stdio.h>
 
int main()
{
    char buf[10] = {0};
    char src[] = "hello %s";
    
    snprintf(buf, sizeof(buf), src);
    
    printf("buf = %s\n", buf);
    
    return 0;
}

輸出結(jié)果如下:

所以程序該這么寫:

#include <stdio.h>
 
int main()
{
    char buf[10] = {0};
    char src[] = "hello %s";
    
    snprintf(buf, sizeof(buf), src, "Ze");
    
    printf("buf = %s\n", buf);
    
    return 0;
}

或者這樣:

#include <stdio.h>
 
int main()
{
    char buf[10] = {0};
    char src[] = "hello Ze";
    
    snprintf(buf, sizeof(buf), src);
    
    printf("buf = %s\n", buf);
    
    return 0;
}

均能輸出正確的結(jié)果:

二、典型問題二

下面的程序輸出什么?為什么?

分析

  • 字符串相關(guān)的函數(shù)均以第一個(gè)出現(xiàn)的 '\0' 作為結(jié)束符
  • 編譯器總是會(huì)在字符串字面量的末尾添加 '\0'
  • 字符串字面量的本質(zhì)為數(shù)組

下面來(lái)編程驗(yàn)證:

#include <stdio.h>
#include <string.h>
 
int main()
{
    #define STR "Hello, \0D.T.Software\0"
    
    char* src = STR;
    char buf[255] = {0};
    
    snprintf(buf, sizeof(buf), src);
    
    printf("strlen(STR) = %d\n", strlen(STR));
    printf("sizeof(STR) = %d\n", sizeof(STR));
    
    printf("strlen(src) = %d\n", strlen(src));
    printf("sizeof(src) = %d\n", sizeof(src));
    
    printf("strlen(buf) = %d\n", strlen(buf));
    printf("sizeof(buf) = %d\n", sizeof(buf));
    
    printf("src = %s\n", src);
    printf("buf = %s\n", buf);
    
    return 0;
}

輸出結(jié)果如下:

注意 sizeof(src) = 4,這是因?yàn)?src 為指針

三、典型問題三

下面的程序輸出什么?為什么?

分析

  • 字符串之間的相等比較需要用 strcmp 完成
  • 不可直接用 == 進(jìn)行字符串直接的比較
  • 完全相同的字符串字面量的 == 比較結(jié)果為 false

一些現(xiàn)代編譯器能夠?qū)⑾嗤淖址置媪坑成涞酵粋€(gè)無(wú)名字符數(shù)組,因此 == 比較結(jié)果為 true 。

下面來(lái)編程驗(yàn)證:

#include <stdio.h>
#include <string.h>
 
int main()
{
    #define S1 "D.T.Software"
    #define S2 "D.T.Software"
    
    if( S1 == S2 )
    {
        printf("Equal\n");
    }
    else
    {
        printf("Non Equal\n");
    }
    
    if( strcmp(S1, S2) == 0 )
    {
        printf("Equal\n");
    }
    else
    {
        printf("Non Equal\n");
    }
    
    return 0;
}

在 gcc 編譯器中輸出結(jié)果如下:

在 VS2012 編譯器的輸出結(jié)果也是:

四、典型問題四

字符串循環(huán)右移

void right_shift_r(const char* src, char* result, unsigned int n);

函數(shù)功能:將輸入字符串 src 循環(huán)右移 n 位,result 為輸出結(jié)果

要求:以效率最高的方式實(shí)現(xiàn)。

示例:

"abcde" -- 2 --> "deabc"

"abcde" -- 8 --> "cdeab"

來(lái)看一個(gè)示意圖:

代碼如下:

#include <stdio.h>
#include <string.h>
 
void right_shift_r(const char* src, char* result, unsigned int n)
{
    const unsigned int LEN = strlen(src);
    int i = 0;
        
    for(i=0; i < LEN; i++)
    {
        result[(n + i) % LEN] = src[i];
    }
    
    result[LEN] = '\0';
}
 
int main()
{
    char result[255] = {0};
    
    right_shift_r("abcde", result, 2);
    
    printf("%s\n", result);
    
    right_shift_r("abcde", result, 5);
    
    printf("%s\n", result);
    
    right_shift_r("abcde", result, 8);
    
    printf("%s\n", result);
    
    return 0;
}

輸出結(jié)果如下:

到此這篇關(guān)于C語(yǔ)言實(shí)例問題探究字符串的應(yīng)用的文章就介紹到這了,更多相關(guān)C語(yǔ)言 字符串內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++模擬2D牛頓力學(xué)效果的示例代碼

    C++模擬2D牛頓力學(xué)效果的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何利用C++模擬2D牛頓力學(xué)效果,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以了解一下
    2023-06-06
  • C語(yǔ)言矩陣連乘 (動(dòng)態(tài)規(guī)劃)詳解

    C語(yǔ)言矩陣連乘 (動(dòng)態(tài)規(guī)劃)詳解

    這篇文章主要介紹了C語(yǔ)言矩陣連乘 (動(dòng)態(tài)規(guī)劃)詳解的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • C語(yǔ)言科學(xué)計(jì)算入門之矩陣乘法的相關(guān)計(jì)算

    C語(yǔ)言科學(xué)計(jì)算入門之矩陣乘法的相關(guān)計(jì)算

    這篇文章主要介紹了C語(yǔ)言科學(xué)計(jì)算入門之矩陣乘法的相關(guān)計(jì)算,文章中還介紹了矩陣相關(guān)的斯特拉森算法的實(shí)現(xiàn),需要的朋友可以參考下
    2015-12-12
  • C++ 強(qiáng)制類型轉(zhuǎn)換詳解

    C++ 強(qiáng)制類型轉(zhuǎn)換詳解

    這篇文章主要介紹的是C++ 強(qiáng)制類型轉(zhuǎn)換詳解,C語(yǔ)言中的強(qiáng)制轉(zhuǎn)換主要用于普通數(shù)據(jù)類型、指針的強(qiáng)制轉(zhuǎn)換,沒有類型檢查,轉(zhuǎn)換不安全,下面我們來(lái)看看其具體語(yǔ)法及詳細(xì)內(nèi)容
    2021-11-11
  • C++實(shí)現(xiàn)LeetCode(16.最近三數(shù)之和)

    C++實(shí)現(xiàn)LeetCode(16.最近三數(shù)之和)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(16.最近三數(shù)之和),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • 深入解析Linux下\r\n的問題

    深入解析Linux下\r\n的問題

    本篇文章是對(duì)Linux下\r\n的問題進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • 將CString字符串輸入轉(zhuǎn)化成整數(shù)的實(shí)現(xiàn)方法

    將CString字符串輸入轉(zhuǎn)化成整數(shù)的實(shí)現(xiàn)方法

    下面小編就為大家?guī)?lái)一篇將CString字符串輸入轉(zhuǎn)化成整數(shù)的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2016-09-09
  • C語(yǔ)言三子棋游戲的簡(jiǎn)單設(shè)計(jì)

    C語(yǔ)言三子棋游戲的簡(jiǎn)單設(shè)計(jì)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言三子棋游戲的簡(jiǎn)單設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • C++OOP對(duì)象和類的詳細(xì)講解

    C++OOP對(duì)象和類的詳細(xì)講解

    這篇文章主要介紹了C++面相對(duì)象編程中的類與對(duì)象的特性與概念,OOP面向?qū)ο笳Z(yǔ)言相對(duì)C語(yǔ)言這樣面相過程的語(yǔ)言來(lái)說具有類和對(duì)象以及方法這樣的特性,需要的朋友可以參考下
    2021-08-08
  • C語(yǔ)言實(shí)現(xiàn)俄羅斯方塊

    C語(yǔ)言實(shí)現(xiàn)俄羅斯方塊

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)俄羅斯方塊,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-11-11

最新評(píng)論