【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 總結
分析一下上面的宏定義:
先用sizeof數(shù)組求出整個數(shù)組所占的內(nèi)存大小 a;
其次用sizeof求出單個數(shù)組元素所占的內(nèi)存大小 b;
最后利用數(shù)組四線性存儲的特性,使用除法,用 a 除以 b,即可求出數(shù)組中元素的個數(shù)。
我們來看一下測試結果:
這個與數(shù)據(jù)定義中的6個元素是保持一致的。
4 更多分享
[架構師李肯]
架構師李肯 ( 全網(wǎng)同名 ),一個專注于嵌入式IoT領域的架構師。有著近10年的嵌入式一線開發(fā)經(jīng)驗,深耕IoT領域多年,熟知IoT領域的業(yè)務發(fā)展,深度掌握IoT領域的相關技術棧,包括但不限于主流RTOS內(nèi)核的實現(xiàn)及其移植、硬件驅(qū)動移植開發(fā)、網(wǎng)絡通訊協(xié)議開發(fā)、編譯構建原理及其實現(xiàn)、底層匯編及編譯原理、編譯優(yōu)化及代碼重構、主流IoT云平臺的對接、嵌入式IoT系統(tǒng)的架構設計等等。擁有多項IoT領域的發(fā)明專利,熱衷于技術分享,有多年撰寫技術博客的經(jīng)驗積累,堅信【知識改變命運,技術改變世界】!
-
C語言
+關注
關注
180文章
7604瀏覽量
136824 -
數(shù)組
+關注
關注
1文章
417瀏覽量
25947 -
宏定義
+關注
關注
0文章
50瀏覽量
9012
發(fā)布評論請先 登錄
相關推薦
評論