日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無(wú)先后,達(dá)者為師

網(wǎng)站首頁(yè) 編程語(yǔ)言 正文

C語(yǔ)言簡(jiǎn)明講解單引號(hào)與雙引號(hào)的使用_C 語(yǔ)言

作者:清風(fēng)自在?流水潺潺 ? 更新時(shí)間: 2022-06-18 編程語(yǔ)言

一、單引號(hào)和雙引號(hào)

  • C語(yǔ)言中的單引號(hào)用來(lái)表示字符字面量
  • C語(yǔ)言中的雙引號(hào)用來(lái)表示字符串字面量

'a'表示字符字面量,在內(nèi)存中占1個(gè)字節(jié),'a'+1表示'a'的ASCII碼加1,結(jié)果為'b'

"a"表示字符串字面量,在內(nèi)存中占2個(gè)字節(jié),"a"+1表示指針運(yùn)算,結(jié)果指向"a"結(jié)束符'\0'

下面看一段單引號(hào)和雙引號(hào)本質(zhì)的代碼:

#include <stdio.h>
 
int main()
{
    char* p1 =  1 ;
    char* p2 = '1';
    char* p3 = "1";
    printf("%s, %s, %s", p1, p2, p3);
    printf('\n');
    printf("\n");
    return 0;
}

編譯后會(huì)有警告,繼續(xù)運(yùn)行會(huì)發(fā)生段錯(cuò)誤,如下:

究竟問(wèn)題出現(xiàn)在哪里呢?下面先把打印語(yǔ)句注釋掉并運(yùn)行:

#include <stdio.h>
 
int main()
{
    char* p1 =  1 ;
    char* p2 = '1';
    char* p3 = "1";
    //printf("%s, %s, %s", p1, p2, p3);
    //printf('\n');
    //printf("\n");
    return 0;
}

編譯運(yùn)行雖然有警告,但是沒(méi)有段錯(cuò)誤,那么段錯(cuò)誤肯定是打印語(yǔ)句那里了

把打印語(yǔ)句去掉注釋

#include <stdio.h>
 
int main()
{
    char* p1 =  1 ;
    char* p2 = '1';
    char* p3 = "1";
    printf("%s, %s, %s", p1, p2, p3);
    //printf('\n');
    //printf("\n");
    return 0;
}

編譯運(yùn)行后果然出現(xiàn)了段錯(cuò)誤

究竟是怎么回事呢?接著往下看

二、小貼士

  • 字符字面量被編譯為對(duì)應(yīng)的 ASCII 碼
  • 字符串字面量被編譯為對(duì)應(yīng)的內(nèi)存地址
  • printf 的第一個(gè)參數(shù)被當(dāng)成字符串內(nèi)存地址
  • 內(nèi)存的低地址空間不能在程序中隨意訪問(wèn)

三、程序?qū)嵗治?

注意:字符 '1' 所對(duì)應(yīng)的 ASCII 碼就是十六進(jìn)制的 0x00000031

0x08048000這個(gè)內(nèi)存地址是非常特別的內(nèi)存地址,所有低于這個(gè)地址的內(nèi)存空間是不能隨便訪問(wèn)的,一旦訪問(wèn),就會(huì)發(fā)生段錯(cuò)誤。程序里面的字符串編譯之后得到的地址都是大于0x08048000,所以在程序中可以訪問(wèn)。

所以說(shuō) 1 和 '1' 的內(nèi)存地址都不能訪問(wèn),訪問(wèn)了就會(huì)出現(xiàn)段錯(cuò)誤。如果把printf("%s, %s, %s", p1, p2, p3); 注釋打印下面的語(yǔ)句會(huì)發(fā)生什么?

#include <stdio.h>
int main()
{
    char* p1 =  1 ;
    char* p2 = '1';
    char* p3 = "1";
    //printf("%s, %s, %s", p1, p2, p3);
    printf('\n');
    printf("\n");
    return 0;
}

輸出結(jié)果如下,還是會(huì)發(fā)生段錯(cuò)誤:

四、程序?qū)嵗治?

'\n' 字符字面量還是處于地址值區(qū)間,所以訪問(wèn)這個(gè)地址就會(huì)發(fā)生段錯(cuò)誤。

如果把 printf('\n'); 注釋掉

#include <stdio.h>
 
int main()
{
    char* p1 =  1 ;
    char* p2 = '1';
    char* p3 = "1";
    //printf("%s, %s, %s", p1, p2, p3);
    //printf('\n');
    printf("\n");
    return 0;
}

編譯就不會(huì)出錯(cuò),而且換了一行:

五、容易混淆的代碼

這段代碼的本意是如果字符 c 是 "\t" 或者 " " 或者 "\n",,則輸入字符。

#include <stdio.h>
 
int main()
{
    char c = " ";
    while( (c == "\t") || (c == " ") || (c == "\n") )
    {
        scanf("%c", &c);
    }
    return 0;
}

編譯運(yùn)行后,發(fā)現(xiàn)程序并沒(méi)有讓我們輸入:

在進(jìn)行解釋之前,先看下面這樣會(huì)發(fā)生什么:

分析:

1)編譯后字符串"string"的內(nèi)存地址被賦值給變量 c

2)內(nèi)存地址占用 4個(gè)字節(jié),而變量 c 只占用1個(gè)字節(jié)

3)由于類型不同,賦值后產(chǎn)生截?cái)?/p>

所以說(shuō) char c = " "; 賦值后產(chǎn)生截?cái)啵敲?while 里面的語(yǔ)句也就不會(huì)執(zhí)行了,這段程序是混淆了字符和字符串的概念。

可以這么改:

#include <stdio.h>
 
int main()
{
    char c = ' ';
    while( (c == '\t') || (c == ' ') || (c == '\n') )
    {
        scanf("%c", &c);
    }
    return 0;
}

這樣就能正確了:

六、小結(jié)

  • 單引號(hào)括起來(lái)的單個(gè)字符代表整數(shù)
  • 雙引號(hào)括起來(lái)的字符代表字符指針
  • 編譯器接受字符和字符串的比較,無(wú)任何意義
  • 編譯器允許字符串對(duì)字符變量賦值,只能得到錯(cuò)誤

原文鏈接:https://blog.csdn.net/weixin_43129713/article/details/123333915

欄目分類
最近更新