C語言實(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ù)組
下面來編程驗(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è)無名字符數(shù)組,因此 == 比較結(jié)果為 true 。
下面來編程驗(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"
來看一個(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語言實(shí)例問題探究字符串的應(yīng)用的文章就介紹到這了,更多相關(guān)C語言 字符串內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- C語言字符串函數(shù),字符函數(shù),內(nèi)存函數(shù)使用及模擬實(shí)現(xiàn)
- C語言超全面講解字符串函數(shù)
- C語言超詳細(xì)講解字符串函數(shù)和內(nèi)存函數(shù)
- C語言字符串函數(shù)與內(nèi)存函數(shù)精講
- C語言詳細(xì)分析常見字符串函數(shù)與模擬實(shí)現(xiàn)
- C語言的字符函數(shù)和字符串函數(shù)詳解
- C語言進(jìn)階教程之字符函數(shù)&字符串函數(shù)
- C語言字符串函數(shù)介紹與模擬實(shí)現(xiàn)詳解
- C語言字符串函數(shù)模擬實(shí)現(xiàn)流程介紹
相關(guān)文章
C語言矩陣連乘 (動(dòng)態(tài)規(guī)劃)詳解
這篇文章主要介紹了C語言矩陣連乘 (動(dòng)態(tài)規(guī)劃)詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05
C語言科學(xué)計(jì)算入門之矩陣乘法的相關(guān)計(jì)算
這篇文章主要介紹了C語言科學(xué)計(jì)算入門之矩陣乘法的相關(guān)計(jì)算,文章中還介紹了矩陣相關(guān)的斯特拉森算法的實(shí)現(xiàn),需要的朋友可以參考下2015-12-12
C++實(shí)現(xiàn)LeetCode(16.最近三數(shù)之和)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(16.最近三數(shù)之和),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
將CString字符串輸入轉(zhuǎn)化成整數(shù)的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄獙String字符串輸入轉(zhuǎn)化成整數(shù)的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-09-09

