C/C++中獲取數(shù)組長度的方法示例
學過C/C++的人都知道,在C/C++中并沒有提供直接獲取數(shù)組長度的函數(shù),對于存放字符串的字符數(shù)組提供了一個strlen函數(shù)獲取其長度,那么對于其他類型的數(shù)組如何獲取他們的長度呢?
其中一種方法是使用sizeof(array) / sizeof(array[0]), 在C語言中習慣上在使用時都把它定義成一個宏,比如:
#define GET_ARRAY_LEN(array,len) {len = (sizeof(array) / sizeof(array[0]));}
而在C++中則可以使用模板技術(shù)定義一個函數(shù),比如:
template <class T> int getArrayLen(T& array) { return (sizeof(array) / sizeof(array[0])); }
這樣對于一些簡單的數(shù)組可以使用這個宏或者這個函數(shù)來獲取數(shù)組的長度了。
以下是兩個Demo程序,一個C語言的,一個C++的:
注意:若數(shù)組為存儲字符串的字符數(shù)組,即以雙引號括起來的字符串整體初始化的字符數(shù)組
例如:
char a[]="abcdefg"
或者
char a[]={"abcdefg"}
則所求得的長度為字符數(shù)組的長度,而不是對應的字符串的長度,要求字符串的長度還需要減一。原因為存儲字符串的字符數(shù)組末尾有一個'\0'字符,需要去掉它。
對于下例:
char a[]="abcdefg"; sizeof(a)/sizeof(a[0])=8;
要求字符串長度的話應該減1.
但對于:
char a[]={'a','b','c','d','e','f','g'}; sizeof(a)/sizeof(a[0])=7
C語言實例如下:
#include <stdio.h> #include <stdlib.h> #define GET_ARRAY_LEN(array,len) {len = (sizeof(array) / sizeof(array[0]));} //定義一個帶參數(shù)的宏,將數(shù)組長度存儲在變量len中 int main() { char a[] = {'1','2','3','4'}; int len; GET_ARRAY_LEN(a,len) //調(diào)用預定義的宏,取得數(shù)組a的長度,并將其存儲在變量len中 printf("%d\n",len); system("pause"); return 0; }
輸出結(jié)果為:4
C++實例如下:
#include <iostream> using namespace std; template <class T> int getArrayLen(T& array) //使用模板定義一個函數(shù)getArrayLen,該函數(shù)將返回數(shù)組array的長度 { return (sizeof(array) / sizeof(array[0])); } int main() { char a[] = {'1','2','3'}; cout << getArrayLen(a) << endl; return 0; }
輸出結(jié)果為:3
相關(guān)文章
C++數(shù)據(jù)結(jié)構(gòu)紅黑樹全面分析
今天的這一篇博客,我要跟大家介紹二叉搜索樹中的另一顆樹——紅黑樹,它主要是通過控制顏色來控制自身的平衡,但它的平衡沒有AVL樹的平衡那么嚴格2022-02-02VC編程控件類HTControl之CHTGDIManager GDI資源管理類用法解析
這篇文章主要介紹了VC編程控件類HTControl之CHTGDIManager GDI資源管理類用法解析,需要的朋友可以參考下2014-08-08Java?C++?算法題解leetcode669修剪二叉搜索樹示例
這篇文章主要為大家介紹了Java?C++?算法題解leetcode669修剪二叉搜索樹示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09