Code for dynamic array by entering size and storing it into "n" variable, but I want to get the array length from a template method and not using "n".
int* a = NULL; // Pointer to int, initialize to nothing. int n; // Size needed for array cin >> n; // Read in the size a = new int[n]; // Allocate n ints and save ptr in a. for (int i=0; i<n; i++) { a[i] = 0; // Initialize all elements to zero. } . . . // Use a as a normal array delete [] a; // When done, free memory pointed to by a. a = NULL; // Clear a to prevent using invalid memory reference. This code is similar, but using a dynamic array:
#include <cstddef> #include <iostream> template< typename T, std::size_t N > inline std::size_t size( T(&)[N] ) { return N ; } int main() { int a[] = { 0, 1, 2, 3, 4, 5, 6 }; const void* b[] = { a, a+1, a+2, a+3 }; std::cout << size(a) << '\t' << size(b) << '\n' ; }
std::vectorinstead of juggling pointers yourself. (If you really want to juggle pointers, then the answer is no. So don't do that.)vector.newis a pointer to a the first element of an array.