C語(yǔ)言實(shí)例問題探究字符串函數(shù)的應(yīng)用
一、典型問題一
下面的程序輸出什么?為什么?
分析
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)文章希望大家以后多多支持腳本之家!
- C語(yǔ)言字符串函數(shù),字符函數(shù),內(nèi)存函數(shù)使用及模擬實(shí)現(xiàn)
- C語(yǔ)言超全面講解字符串函數(shù)
- C語(yǔ)言超詳細(xì)講解字符串函數(shù)和內(nèi)存函數(shù)
- C語(yǔ)言字符串函數(shù)與內(nèi)存函數(shù)精講
- C語(yǔ)言詳細(xì)分析常見字符串函數(shù)與模擬實(shí)現(xiàn)
- C語(yǔ)言的字符函數(shù)和字符串函數(shù)詳解
- C語(yǔ)言進(jìn)階教程之字符函數(shù)&字符串函數(shù)
- C語(yǔ)言字符串函數(shù)介紹與模擬實(shí)現(xiàn)詳解
- C語(yǔ)言字符串函數(shù)模擬實(shí)現(xiàn)流程介紹
相關(guān)文章
C語(yǔ)言矩陣連乘 (動(dòng)態(tài)規(guī)劃)詳解
這篇文章主要介紹了C語(yǔ)言矩陣連乘 (動(dòng)態(tài)規(guī)劃)詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05C語(yǔ)言科學(xué)計(jì)算入門之矩陣乘法的相關(guān)計(jì)算
這篇文章主要介紹了C語(yǔ)言科學(xué)計(jì)算入門之矩陣乘法的相關(guān)計(jì)算,文章中還介紹了矩陣相關(guān)的斯特拉森算法的實(shí)現(xiàn),需要的朋友可以參考下2015-12-12C++實(shí)現(xiàn)LeetCode(16.最近三數(shù)之和)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(16.最近三數(shù)之和),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07將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-09C語(yǔ)言三子棋游戲的簡(jiǎn)單設(shè)計(jì)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言三子棋游戲的簡(jiǎn)單設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10