国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

一篇就夠了(建議收藏)——超詳解sizeof與strlen的用法

Taonce / 3927人閱讀

摘要:萬(wàn)字詳解與的用法數(shù)組名的意義一維數(shù)組用法字符數(shù)組用法的用法字符串?dāng)?shù)組用法的用法指針與字符串用法用法二維數(shù)組數(shù)組名的意義在講所有東西之前,需要先明確一個(gè)關(guān)鍵問題數(shù)組名,這里的數(shù)組名表示整個(gè)數(shù)組,計(jì)算的是整個(gè)數(shù)組的大小,單

數(shù)組名的意義

在講所有東西之前,需要先明確一個(gè)關(guān)鍵問題

  1. sizeof(數(shù)組名),這里的數(shù)組名表示整個(gè)數(shù)組,計(jì)算的是整個(gè)數(shù)組的大小, 單位是字節(jié)
  2. &數(shù)組名,這里的數(shù)組名表示整個(gè)數(shù)組,取出的是整個(gè)數(shù)組的地址
  3. 除此之外所有的數(shù)組名表示首元素的地址

一維數(shù)組

sizeof用法

    //一維數(shù)組	int a[] = { 1,2,3,4 };	printf("%d/n", sizeof(a));	printf("%d/n", sizeof(a + 0));	printf("%d/n", sizeof(*a));	printf("%d/n", sizeof(a + 1));	printf("%d/n", sizeof(a[1]));	printf("%d/n", sizeof(&a));	printf("%d/n", sizeof(*&a));	printf("%d/n", sizeof(&a + 1));	printf("%d/n", sizeof(&a[0]));	printf("%d/n", sizeof(&a[0] + 1));

運(yùn)行結(jié)果:

解:

	printf("%d/n", sizeof(a));  16字節(jié)

因?yàn)閕nt a[ ]里有4個(gè)元素,每個(gè)元素是int類型,占四個(gè)字節(jié),所以整個(gè)數(shù)組大小為16字節(jié)

	printf("%d/n", sizeof(a + 0)); 4/8字節(jié)在32/64位平臺(tái)下

此時(shí)此刻的數(shù)組名a表示的是首元素地址,首元素地址+0,還是首元素地址,地址的大小為 4/8在32/64位平臺(tái)下

     printf("%d/n", sizeof(*a)); 4字節(jié)

a是數(shù)組名,表示首元素地址,然后對(duì)首元素地址解引用,所以*a就是首元素,首元素是個(gè)int型,大小為4字節(jié)

	printf("%d/n", sizeof(a + 1)); 4/8字節(jié)在32/64位平臺(tái)下

a是數(shù)組名,表示首元素地址,a+1是第二個(gè)元素的地址,所以大小為4/8字節(jié)在32/64位平臺(tái)下

	printf("%d/n", sizeof(a[1])); 4字節(jié)

a[1]就是第二個(gè)元素,大小為4字節(jié)

	printf("%d/n", sizeof(&a)); 大小為4/8字節(jié)在32/64位平臺(tái)下

&a取出的是整個(gè)數(shù)組的地址(從數(shù)值的角度看等于首元素地址),只要是地址,大小就為4/8字節(jié)在32/64位平臺(tái)下

	printf("%d/n", sizeof(*&a)); 16字節(jié)

&a取出的是整個(gè)數(shù)組的地址,* &a是對(duì)整個(gè)數(shù)組的地址解引用,拿到的是整個(gè)數(shù)組,所以大小為16字節(jié)

	printf("%d/n", sizeof(&a + 1)); 4/8字節(jié)在32/64位平臺(tái)下

&a是數(shù)組的地址,&a+1是數(shù)組的地址+1,雖然相當(dāng)于跳過了整個(gè)數(shù)組,但還是一個(gè)地址,所以大小還是4/8

	printf("%d/n", sizeof(&a[0])); 4/8字節(jié)在32/64位平臺(tái)下

第1個(gè)元素地址,地址大小為4/8字節(jié)在32/64位平臺(tái)下

	printf("%d/n", sizeof(&a[0] + 1)); 4/8字節(jié)在32/64位平臺(tái)下

第一個(gè)元素地址+1,就是第二個(gè)元素地址,地址大小為4/8字節(jié)在32/64位平臺(tái)下

字符數(shù)組

sizeof用法

    char arr[] = {"a","b","c","d","e","f"};    printf("%d/n", sizeof(arr));    printf("%d/n", sizeof(arr+0));    printf("%d/n", sizeof(*arr));    printf("%d/n", sizeof(arr[1]));    printf("%d/n", sizeof(&arr));    printf("%d/n", sizeof(&arr+1));    printf("%d/n", sizeof(&arr[0]+1));

運(yùn)行結(jié)果:

解:

    printf("%d/n", sizeof(arr)); 6

此時(shí)此刻,sizeof(數(shù)組名) 計(jì)算的是整個(gè)數(shù)組的大小,這個(gè)數(shù)組有6個(gè)char類型元素,所以大小為6字節(jié)

    printf("%d/n", sizeof(arr+0)); 4/8

這里的arr表示首元素地址,+0之后還是首元素a的地址,只要是地址,所以大小為4/8字節(jié)

    printf("%d/n", sizeof(*arr)); 1

arr是首元素地址,對(duì)首元素地址解引用,即得到首元素 a ,a是char類型,所以大小為1

    printf("%d/n", sizeof(arr[1])); 1

arr[1]表示的就是第二個(gè)元素b,大小為1

    printf("%d/n", sizeof(&arr)); 4/8

這里&arr取的是整個(gè)數(shù)組的地址,是地址,所以大小為4/8字節(jié)

    printf("%d/n", sizeof(&arr+1)); 4/8

&arr是數(shù)組的地址,&arr+1是數(shù)組的地址+1,雖然相當(dāng)于跳過了整個(gè)數(shù)組,但還是一個(gè)地址,所以大小還是4/8字節(jié)

    printf("%d/n", sizeof(&arr[0]+1)); 4/8

&arr[0]是首元素地址,+1后取到的是第二位元素的地址,也就是 b 的地址,大小為4/8字節(jié);

strlen的用法

strlen庫(kù)函數(shù)是什么?請(qǐng)看下圖

請(qǐng)看題:

    char arr[] = {"a","b","c","d","e","f"};    printf("%d/n", strlen(arr));    printf("%d/n", strlen(arr+0));    printf("%d/n", strlen(*arr));    printf("%d/n", strlen(arr[1]));    printf("%d/n", strlen(&arr));    printf("%d/n", strlen(&arr+1));    printf("%d/n", strlen(&arr[0]+1));

解:

    printf("%d/n", strlen(arr)); 結(jié)果是未知數(shù)即隨機(jī)值

因?yàn)閍rr是首元素地址,strlen函數(shù)拿到一個(gè)地址,從這個(gè)地址一路往后讀取計(jì)數(shù),直到讀到 /0 為止,然鵝在arr這個(gè)字符數(shù)組里,沒有 /0 讓其讀取,所以它會(huì)順著內(nèi)存地址一直往后,具體哪個(gè)內(nèi)存單元里存有 /0 是未知的,所以長(zhǎng)度結(jié)果就是個(gè)隨機(jī)未知數(shù)

printf("%d/n", strlen(arr+0)); 結(jié)果是隨機(jī)值

arr是首元素地址,+0后還是首元素地址,情況與上一題同理,結(jié)果是隨機(jī)數(shù)

    printf("%d/n", strlen(*arr)); 系統(tǒng)報(bào)錯(cuò)

*arr是對(duì)首元素地址解引用,得到的就是 字符a ,strlen接收到的其實(shí)是字符a的ASCII碼值97 ,這個(gè)97不是一個(gè)合法地址,是個(gè)野指針,所以這行代碼會(huì)報(bào)錯(cuò)

    printf("%d/n", strlen(arr[1])); 系統(tǒng)報(bào)錯(cuò)

arr[1]是第二位元素,就是字符 b ,strlen接收到的是字符 b 的ASCII碼值98,與上同理,會(huì)報(bào)錯(cuò)

    printf("%d/n", strlen(&arr)); 隨機(jī)值

&arr取到的是整個(gè)數(shù)組的地址,它的實(shí)際上等于首元素地址,由于strlen函數(shù)的類型是char* ,傳過來之后會(huì)進(jìn)行一個(gè)類型的隱式轉(zhuǎn)換,地址類型可能會(huì)不一樣,但是strlen能接收這個(gè)地址,即接收到首元素地址并由此往后計(jì)數(shù),所以結(jié)果也是一個(gè)隨機(jī)值

    printf("%d/n", strlen(&arr+1));結(jié)果是一個(gè)隨機(jī)值,與strlen(&arr)得到的隨機(jī)值相差6

&arr是取整個(gè)數(shù)組的地址,+1是跳過整個(gè)數(shù)組,拿到的是整個(gè)數(shù)組之后的地址,所以同理,結(jié)果也是一個(gè)隨機(jī)值,只不過這個(gè)隨機(jī)值與strlen(arr)得到的隨機(jī)值相差6,如圖:

    printf("%d/n", strlen(&arr[0]+1)); 隨機(jī)值

&arr[0]是取第一個(gè)元素地址,+1是取到第二個(gè)元素地址,即從 字符b 開始向后計(jì)數(shù),但是不知道 /0 會(huì)出現(xiàn)在后邊內(nèi)存的哪個(gè)位置,所以結(jié)果也是隨機(jī)數(shù)

字符串?dāng)?shù)組

sizeof用法

    char arr[] = "abcdef";    printf("%d/n", sizeof(arr));    printf("%d/n", sizeof(arr+0));    printf("%d/n", sizeof(*arr));    printf("%d/n", sizeof(arr[1]));    printf("%d/n", sizeof(&arr));    printf("%d/n", sizeof(&arr+1));    printf("%d/n", sizeof(&arr[0]+1));

解:

    printf("%d/n", sizeof(arr)); 7字節(jié)

abcdef/0 一共7個(gè)字節(jié)

    printf("%d/n", sizeof(arr+0)); 4/8

arr表示首元素字符地址,+0之后還是首元素字符 a 的地址,大小為4/8字節(jié)

    printf("%d/n", sizeof(*arr)); 1字節(jié)

arr是首元素地址,解引用*arr后就是首元素 字符a,大小為1字節(jié)

    printf("%d/n", sizeof(arr[1])); 1字節(jié)

arr[1] 表示第二個(gè)元素,也就是字符 b ,大小為1字節(jié)

    printf("%d/n", sizeof(&arr)); 4/8字節(jié)

&arr 是整個(gè)數(shù)組的地址,數(shù)組的地址也是地址,大小為4/8字節(jié)

    printf("%d/n", sizeof(&arr+1)); 4/8字節(jié)

&arr 是數(shù)組的地址,&arr+1是跳過整個(gè)數(shù)組,得到數(shù)組后一位的地址,4//8字節(jié)

    printf("%d/n", sizeof(&arr[0]+1)); 4//8字節(jié)

&arr[0]是第一個(gè)元素地址,&arr[0]+1 是第二個(gè)元素地址,大小為4/8字節(jié)

strlen的用法

    char arr[] = "abcdef";    printf("%d/n", strlen(arr));    printf("%d/n", strlen(arr+0));    printf("%d/n", strlen(*arr));    printf("%d/n", strlen(arr[1]));    printf("%d/n", strlen(&arr));    printf("%d/n", strlen(&arr+1));    printf("%d/n", strlen(&arr[0]+1));

解:

    printf("%d/n", strlen(arr)); 6

strlen只對(duì)abcdef計(jì)數(shù), 不算/0一共6個(gè)字符,也就是6字節(jié)

    printf("%d/n", strlen(arr+0)); 6

arr是首元素地址,+0后還是首元素的地址,從首地址開始計(jì)數(shù),仍然為6字節(jié)

    printf("%d/n", strlen(*arr)); 系統(tǒng)報(bào)錯(cuò)    printf("%d/n", strlen(arr[1])); 系統(tǒng)報(bào)錯(cuò)

*arr傳入的是數(shù)組首元素,就是字符a,strlen接收到的其實(shí)是字符a的ASCII碼值97,97不是合法地址,相當(dāng)于野指針,所以會(huì)報(bào)錯(cuò)
arr[1]同理,傳入的是第二個(gè)元素字符 b ,strlen接收到的是字符b 的ASCII碼值98,是非法地址,所以也會(huì)報(bào)錯(cuò)

    printf("%d/n", strlen(&arr)); 6

&arr是取得整個(gè)數(shù)組的地址,數(shù)值上等于首元素地址,strlen接收到的就是首元素地址,于是從首元素開始計(jì)數(shù),結(jié)果為6字節(jié)

    printf("%d/n", strlen(&arr+1)); 隨機(jī)值


&arr+1得到的地址如上圖所示,一直向后讀取,不知道什么時(shí)候才能讀取到/0,所以strlen得到的結(jié)果為隨機(jī)值

    printf("%d/n", strlen(&arr[0]+1));5字節(jié)

&arr[0]是第一個(gè)元素地址,+1之后得到第二個(gè)元素地址,從第二個(gè)元素地址開始讀取,讀到/0前,一共5個(gè)字節(jié)

指針與字符串

sizeof用法

    const char *p = "abcdef";    printf("%d/n", sizeof(p));    printf("%d/n", sizeof(p+1));    printf("%d/n", sizeof(*p));    printf("%d/n", sizeof(p[0]));    printf("%d/n", sizeof(&p));    printf("%d/n", sizeof(&p+1));    printf("%d/n", sizeof(&p[0]+1));

解:

    printf("%d/n", sizeof(p)); 4/8字節(jié)

p是一個(gè)指針變量,存的是字符串首元素地址,所以是4/8字節(jié)

    printf("%d/n", sizeof(p+1)); 4/8字節(jié)

p是一個(gè)指針變量,存的是字符串首元素址,+1之后就是字符串第二個(gè)元素的地址,也就是 b 的地址,是4/8個(gè)字節(jié)

    printf("%d/n", sizeof(*p)); 1字節(jié)

p是一個(gè)指針變量,存的是字符串首元素地址,對(duì)其解引用,*p得到的是字符 a ,類型為char,大小為1個(gè)字節(jié)

    printf("%d/n", sizeof(p[0])); 1字節(jié)

p[0] = *(p+0) = *p,這三種寫法表示的都是首元素字符 a ,大小為1個(gè)字節(jié)

    printf("%d/n", sizeof(&p)); 4/8字節(jié)

p是一個(gè)指針變量,是一個(gè)地址,對(duì)指針變量取地址,得到的是一個(gè)地址的地址,還是一個(gè)地址,所以大小還是4/8字節(jié)

    printf("%d/n", sizeof(&p+1)); 4/8字節(jié)

p是個(gè)指針變量,字符串通過指針存到內(nèi)存中,其實(shí)也可以理解成這是內(nèi)存中一塊連續(xù)的儲(chǔ)存空間,就像數(shù)組一樣,這里的 &p+1 ,p是一個(gè)指向字符串首元素的一級(jí)指針,&p是指針變量p的地址,是一個(gè)二級(jí)指針,+1之后,相當(dāng)于二級(jí)指針+1,指向的是一塊我們不知道的未知空間,但說到底還是一個(gè)地址,大小仍是4/8字節(jié),如圖所示:

    printf("%d/n", sizeof(&p[0]+1)); 4/8字節(jié)

字符串也是一塊連續(xù)空間,可以像數(shù)組一樣通過 [ ] 訪問p[0] = *(p+0) = *p這三種表示方法都可以表示字符串元素,這里&p[0]表示首元素地址,+1就是第二個(gè)元素字符b的地址,是地址,大小為4/8字節(jié)

strlen用法

    const char *p = "abcdef";    printf("%d/n", strlen(p));    printf("%d/n", strlen(p+1));    printf("%d/n"
            
                     
             
               

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/119669.html

相關(guān)文章

  • Java3y文章目錄導(dǎo)航

    摘要:前言由于寫的文章已經(jīng)是有點(diǎn)多了,為了自己和大家的檢索方便,于是我就做了這么一個(gè)博客導(dǎo)航。 前言 由于寫的文章已經(jīng)是有點(diǎn)多了,為了自己和大家的檢索方便,于是我就做了這么一個(gè)博客導(dǎo)航。 由于更新比較頻繁,因此隔一段時(shí)間才會(huì)更新目錄導(dǎo)航哦~想要獲取最新原創(chuàng)的技術(shù)文章歡迎關(guān)注我的公眾號(hào):Java3y Java3y文章目錄導(dǎo)航 Java基礎(chǔ) 泛型就這么簡(jiǎn)單 注解就這么簡(jiǎn)單 Druid數(shù)據(jù)庫(kù)連接池...

    KevinYan 評(píng)論0 收藏0
  • Scrapy詳解 爬蟲框架入門看這一篇夠了

    摘要:目錄前言架構(gòu)安裝第一個(gè)爬蟲爬取有道翻譯創(chuàng)建項(xiàng)目創(chuàng)建創(chuàng)建解析運(yùn)行爬蟲爬取單詞釋義下載單詞語(yǔ)音文件前言學(xué)習(xí)有一段時(shí)間了,當(dāng)時(shí)想要獲取一下百度漢字的解析,又不想一個(gè)個(gè)漢字去搜,復(fù)制粘貼太費(fèi)勁,考慮到爬蟲的便利性,這篇文章是介紹一個(gè)爬蟲框架, 目錄 前言 架構(gòu) 安裝 第一個(gè)爬蟲:爬取有道翻譯 創(chuàng)建項(xiàng)目 創(chuàng)建Item 創(chuàng)建Spider 解析 運(yùn)行爬蟲-爬取單詞釋義 下載單詞語(yǔ)音文件 ...

    lordharrd 評(píng)論0 收藏0
  • @ConfigurationProperties 注解使用姿勢(shì),這一篇夠了

    摘要:在項(xiàng)目中,為滿足以上要求,我們將大量的參數(shù)配置在或文件中,通過注解,我們可以方便的獲取這些參數(shù)值使用配置模塊假設(shè)我們正在搭建一個(gè)發(fā)送郵件的模塊。這使得在不影響其他模塊的情況下重構(gòu)一個(gè)模塊中的屬性變得容易。 在編寫項(xiàng)目代碼時(shí),我們要求更靈活的配置,更好的模塊化整合。在 Spring Boot 項(xiàng)目中,為滿足以上要求,我們將大量的參數(shù)配置在 application.properties 或...

    SolomonXie 評(píng)論0 收藏0
  • @ConfigurationProperties 注解使用姿勢(shì),這一篇夠了

    摘要:在項(xiàng)目中,為滿足以上要求,我們將大量的參數(shù)配置在或文件中,通過注解,我們可以方便的獲取這些參數(shù)值使用配置模塊假設(shè)我們正在搭建一個(gè)發(fā)送郵件的模塊。這使得在不影響其他模塊的情況下重構(gòu)一個(gè)模塊中的屬性變得容易。 在編寫項(xiàng)目代碼時(shí),我們要求更靈活的配置,更好的模塊化整合。在 Spring Boot 項(xiàng)目中,為滿足以上要求,我們將大量的參數(shù)配置在 application.properties 或...

    KoreyLee 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

Taonce

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<