Rediger

Del via


_countof Macro

Computes the number of elements in a statically allocated array.

Syntax

#define _countof(array) (sizeof(array) / sizeof(array[0]))

Parameters

array
The name of an array.

Return value

The number of elements in the array, expressed as a size_t.

Remarks

_countof is implemented as a function-like preprocessor macro. The C++ version has extra template machinery to detect at compile time if a pointer is passed instead of a statically declared array.

Ensure that array is actually an array, not a pointer. In C, _countof produces erroneous results if array is a pointer. In C++, _countof fails to compile if array is a pointer. An array passed as a parameter to a function decays to a pointer, which means that within the function, you can't use _countof to determine the extent of the array.

Requirements

Macro Required header
_countof <stdlib.h>

Example

// crt_countof.cpp
#define _UNICODE
#include <stdio.h>
#include <stdlib.h>
#include <tchar.h>

int main( void )
{
   _TCHAR arr[20], *p;
   printf( "sizeof(arr) = %zu bytes\n", sizeof(arr) );
   printf( "_countof(arr) = %zu elements\n", _countof(arr) );
   // In C++, the following line would generate a compile-time error:
   // printf( "%zu\n", _countof(p) ); // error C2784 (because p is a pointer)

   _tcscpy_s( arr, _countof(arr), _T("a string") );
   // unlike sizeof, _countof works here for both narrow- and wide-character strings
}
sizeof(arr) = 40 bytes
_countof(arr) = 20 elements

See also

sizeof Operator