如何在不依赖#define的情况下转发声明数组大小?

时间:2017-12-01 10:30:24

标签: c++ c++11 forward-declaration

我想构建一个作用于固定大小的矢量/矩阵的库(即函数集合)。我想在主文件中指定此固定大小,而不触及库。我可以使用#define来做到这一点,但我认为这种方法是一种黑客行为,而不是“正确”的方式。我有什么其他方法来实现这一目标?我的想法是先写一个图书馆,然后再不去触摸,甚至再看一遍。

以下是玩具示例,program.cpp

//program.cpp -- Definition of my_external_constant here
const unsigned int array_size = 10;
#define my_external_constant array_size // I am looking for alternatives.
#include "helper.h"

int main(int argc, char* argv[]) {

    test_function1();

    unsigned int X[array_size];
    X[0]=500;X[1]=0;X[2]=9;X[3]=111;X[4]=0;
    print_vector(X,3);

    return 0;
}

然后是helper.h

//helper.h
#ifndef HELPER_H
#define HELPER_H

#include<iostream>

#ifndef my_external_constant    // I want to avoid this...
#define my_external_constant 1  //...and this...
#endif                          //...and this.

void test_function1(void);

//The library uses helper_max_size everywhere, and its value is inherited from outside.
const unsigned int helper_max_size = my_external_constant;
void print_vector(unsigned int[helper_max_size], const unsigned int);

#endif /* HELPER_H */

实施helper.cpp

//helper.cpp
#include "helper.h"

void test_function1(void) {
    std::cout << "Hello world!\n";
    return;
}

void print_vector(unsigned int my_vector[helper_max_size], const unsigned int my_size) {

    for (unsigned int i=0;i<my_size;++i) {
        std::cout << my_vector[i] << " ";
    }
    std::cout << "\n";

    return;
}

该程序应仅包含一个翻译单元,即应按以下方式编译:

g++ -o program program.cpp helper.h helper.cpp

相关:

How do I use extern to share variables between source files?

Declare array size in header file without #define's

1 个答案:

答案 0 :(得分:4)

  

我想在主文件中指定此固定大小,而不触及库。

     

想法是写一个库,然后永远不要触摸,甚至再看一遍。

使用数组大小​​参数化库中的所有实用程序和函数。例如:

// helper.h
template <std::size_t N>
void print_vector(unsigned int(&array)[N], const unsigned int) { /* ... */ }

// program.cpp 
#include <cstddef>
#include "helper.h"

constexpr std::size_t array_size = 10;

int main(int argc, char* argv[]) 
{
    test_function1();

    unsigned int X[array_size];
    X[0]=500;X[1]=0;X[2]=9;X[3]=111;X[4]=0;
    print_vector(X, 3);
}

在Modern C ++中,您应该优先选择std::array而不是C风格的数组。如果需要可调整大小的数组,您可能还想使用std::vector。 E.g:

// helper.h
template <std::size_t N>
void print_vector(const std::array<unsigned int, N>& array, const unsigned int) 
{ 
    /* ... */ 
}

// program.cpp 
#include <cstddef>
#include "helper.h"

constexpr std::size_t array_size = 10;

int main(int argc, char* argv[]) 
{
    test_function1();

    std::array<unsigned int, array_size> X;
    X[0]=500;X[1]=0;X[2]=9;X[3]=111;X[4]=0;
    print_vector(X, 3);
}