zoukankan      html  css  js  c++  java
  • C++:获取数组长度

    C/C++中如何获取数组的长度?
     
    如何获取数组的长度
    2010-12-15 20:49
    C/C++中如何获取数组的长度? 收藏
     
     
    C、C++中没有提供 直接获取数组长度的函数,对于存放字符串的字符数组提供了一个strlen函数获取长度,那么对于其他类型的数组如何获取他们的长度呢?其中一种方法是使 用sizeof(array) / sizeof(array[0]), 在C语言中习惯上在 使用时都把它定义成一个宏,比如#define GET_ARRAY_LEN(array,len) {len = (sizeof(array) / sizeof(array[0]));} 。而在C++中则可以使用模板 技术定义一个函数,比如:
     
    template <class T>
     
    int getArrayLen(T& array)
     
    {
     
    return (sizeof(array) / sizeof(array[0]));
     
    }
     
    这样对于不同类型的数 组都可以使用这个宏或者这个函数来获取数组的长度了。以下是两个Demo程序,一个C语言的,一个C++的:
     
    P.S:若数组为存储 字符串的字符数组,则所求得的长度还需要减一,即对于宏定义: #define GET_ARRAY_LEN(array,len) {len = (sizeof(array) / sizeof(array[0]) - 1 );} ,对于函数定义:
     
    template <class T>
     
    int getArrayLen(T& array)
     
    {
     
    return (sizeof(array) / sizeof(array[0]) - 1);
     
    }
     
    原因为存储字符串的字 符数组末尾有一个''字符,需要去掉它。
     
    【C语言】
     
    #include <stdio.h>
     
    #include <stdlib.h>
     
    #define GET_ARRAY_LEN(array,len){len = (sizeof(array) / sizeof(array[0]));}
     
    //定义一个带参数的 宏,将数组长度存储在变量len中
     
    int main()
     
    {
     
    char a[] = {'1','2','3','4'};
     
    int len;
     
    GET_ARRAY_LEN(a,len)
     
    //调用预定义的宏,取得数组a的长度,并将其存储在变量len中
     
    printf("%d ",len);
     
    system("pause");
     
    return 0;
     
    }
     
    【C++】
     
    #include <iostream>
     
    using namespace std;
     
    template <class T>
     
    int getArrayLen(T& array)
     
    {//使用模板定义一 个函数getArrayLen,该函数将返回数组array的长度
     
    return (sizeof(array) / sizeof(array[0]));
     
    }
     
    int main()
     
    {
     
    char a[] = {'1','2','3'};
     
    cout << getArrayLen(a) << endl;
     
    return 0;
     
    }
    另: 在c++的函数里面,如果把一个数组作为参数传进去,那么这个数组就会退化为一个指针,因而就不知道这个数组的长度(这里的数组指的是静态的而不是new出来的).

     

  • 相关阅读:
    [bzoj4241] 历史研究 (分块)
    [tyvj2054] 四叶草魔杖 (最小生成树 状压dp)
    20180710 考试记录
    [luogu2047 NOI2007] 社交网络 (floyed最短路)
    [luogu2081 NOI2012] 迷失游乐园 (树形期望dp 基环树)
    [luogu1600 noip2016] 天天爱跑步 (树上差分)
    [luogu2216 HAOI2007] 理想的正方形 (2dST表 or 单调队列)
    [poj 3539] Elevator (同余类bfs)
    [BZOJ1999] 树网的核 [数据加强版] (树的直径)
    bzoj2301 [HAOI2011]Problem b
  • 原文地址:https://www.cnblogs.com/XYQ-208910/p/4912871.html
Copyright © 2011-2022 走看看