【C語言經(jīng)典面試題】求數(shù)組元素的個數(shù)的宏定義
經(jīng)典面試題,有必要了解下!
1 問題描述
在C語言中,如何求一個數(shù)組中元素的個數(shù)呢?想想看!
2 示例代碼
為此,我簡單寫一段示例代碼:
?
#include
#include
?
#define ARRAY_SIZE(a) sizeof(a) / sizeof(a[0])
?
int test_array[] = {1, 2, 3, 4, 5, 6};
?
int main(int argc, const char *argv[])
{
printf("cnt: %d\\\\\\\\n", ARRAY_SIZE(test_array));
return 0;
}
重點語句就是: #define ARRAY_SIZE(a) sizeof(a) / sizeof(a[0])
3 總結(jié)
分析一下上面的宏定義:
先用sizeof數(shù)組求出整個數(shù)組所占的內(nèi)存大小 a;
其次用sizeof求出單個數(shù)組元素所占的內(nèi)存大小 b;
最后利用數(shù)組四線性存儲的特性,使用除法,用 a 除以 b,即可求出數(shù)組中元素的個數(shù)。
我們來看一下測試結(jié)果:
這個與數(shù)據(jù)定義中的6個元素是保持一致的。
4 更多分享
[架構(gòu)師李肯]
架構(gòu)師李肯 ( 全網(wǎng)同名 ),一個專注于嵌入式IoT領(lǐng)域的架構(gòu)師。有著近10年的嵌入式一線開發(fā)經(jīng)驗,深耕IoT領(lǐng)域多年,熟知IoT領(lǐng)域的業(yè)務(wù)發(fā)展,深度掌握IoT領(lǐng)域的相關(guān)技術(shù)棧,包括但不限于主流RTOS內(nèi)核的實現(xiàn)及其移植、硬件驅(qū)動移植開發(fā)、網(wǎng)絡(luò)通訊協(xié)議開發(fā)、編譯構(gòu)建原理及其實現(xiàn)、底層匯編及編譯原理、編譯優(yōu)化及代碼重構(gòu)、主流IoT云平臺的對接、嵌入式IoT系統(tǒng)的架構(gòu)設(shè)計等等。擁有多項IoT領(lǐng)域的發(fā)明專利,熱衷于技術(shù)分享,有多年撰寫技術(shù)博客的經(jīng)驗積累,堅信【知識改變命運,技術(shù)改變世界】!
-
C語言
+關(guān)注
關(guān)注
180文章
7604瀏覽量
136683 -
數(shù)組
+關(guān)注
關(guān)注
1文章
417瀏覽量
25939 -
宏定義
+關(guān)注
關(guān)注
0文章
50瀏覽量
9003
發(fā)布評論請先 登錄
相關(guān)推薦
評論