C/C++中獲取數(shù)組長度的方法示例
學(xué)過C/C++的人都知道,在C/C++中并沒有提供直接獲取數(shù)組長度的函數(shù),對于存放字符串的字符數(shù)組提供了一個strlen函數(shù)獲取其長度,那么對于其他類型的數(shù)組如何獲取他們的長度呢?
其中一種方法是使用sizeof(array) / sizeof(array[0]), 在C語言中習(xí)慣上在使用時都把它定義成一個宏,比如:
#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ù)組的長度,而不是對應(yīng)的字符串的長度,要求字符串的長度還需要減一。原因為存儲字符串的字符數(shù)組末尾有一個'\0'字符,需要去掉它。
對于下例:
char a[]="abcdefg"; sizeof(a)/sizeof(a[0])=8;
要求字符串長度的話應(yīng)該減1.
但對于:
char a[]={'a','b','c','d','e','f','g'}; sizeof(a)/sizeof(a[0])=7
C語言實(shí)例如下:
#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)用預(yù)定義的宏,取得數(shù)組a的長度,并將其存儲在變量len中 printf("%d\n",len); system("pause"); return 0; }
輸出結(jié)果為:4
C++實(shí)例如下:
#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
- 淺談C/C++中指針和數(shù)組的不同
- C++小知識:C/C++中不要按值傳遞數(shù)組
- C/C++中接收return返回來的數(shù)組元素方法示例
- C/C++ 動態(tài)數(shù)組的創(chuàng)建的實(shí)例詳解
- C/C++ 數(shù)組和指針及引用的區(qū)別
- 圖文詳解c/c++中的多級指針與多維數(shù)組
- 淺析C/C++,Java,PHP,JavaScript,Json數(shù)組、對象賦值時最后一個元素后面是否可以帶逗號
- Lua教程(五):C/C++操作Lua數(shù)組和字符串示例
- 淺析C語言編程中的數(shù)組越界問題
- C/C++ 避免數(shù)組越界的方法
相關(guān)文章
C++數(shù)據(jù)結(jié)構(gòu)紅黑樹全面分析
今天的這一篇博客,我要跟大家介紹二叉搜索樹中的另一顆樹——紅黑樹,它主要是通過控制顏色來控制自身的平衡,但它的平衡沒有AVL樹的平衡那么嚴(yán)格2022-02-02VC編程控件類HTControl之CHTGDIManager GDI資源管理類用法解析
這篇文章主要介紹了VC編程控件類HTControl之CHTGDIManager GDI資源管理類用法解析,需要的朋友可以參考下2014-08-08Java?C++?算法題解leetcode669修剪二叉搜索樹示例
這篇文章主要為大家介紹了Java?C++?算法題解leetcode669修剪二叉搜索樹示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09