Co je soubor H?
Soubor uložený s příponou h je hlavičkový soubor používaný v souborech C/C++ k zahrnutí deklarace proměnných, konstant a funkcí. Na ně odkazují implementační soubory C++, které obsahují skutečnou implementaci těchto funkcí. Soubor záhlaví .h může také obsahovat další informace, jako jsou definice maker. Na tyto hlavičkové soubory se odkazuje v souborech C/C++ pomocí direktivy #include
.
Nový projekt C++ obvykle obsahuje speciální hlavičkový soubor s názvem stdafx.h soubor, který je výchozím bodem pro všechny kompilační řetězce a všechny hlavičkové soubory mohou být zahrnuty do tohoto jediného souboru. Soubor .h lze otevřít pomocí libovolného textového editoru, Eclipse IDE, Microsoft Visual Studio IDE, Borland C++ kompilátoru a mnoha dalších aplikací.
Formát souboru .H
Soubor .h je prostý textový soubor, který má svá vlastní pravidla pro definování syntaxe. Soubory záhlaví mohou obsahovat následující informace.
Proměnné
– V případě objektově orientovaného programování (OOP) obsahuje soubor záhlaví třídy definice všech proměnných na úrovni třídy, které jsou přístupné napříč soubory zdrojového kódu implementace.
Deklarace metod
- Všechny deklarace metod jsou zahrnuty v hlavičkových souborech .h, aby byly přístupné ve více souborech implementace.
Definice neinline funkcí
- Soubory záhlaví mohou také obsahovat definice neinline metod.
Mapy zpráv
- Soubor záhlaví může také obsahovat mapy zpráv v případě implementace zdrojového kódu MFC. V takovém případě jsou mapy zpráv propojeny s implementací funkčnosti, která je propojena s prvky uživatelského rozhraní, jako je tlačítko, zaškrtávací políčko, přepínače atd.
Chrániče hlavy
Soubory záhlaví mohou způsobit složité chyby, pokud je do stejného souboru zahrnuto více deklarací v důsledku přidání jiných souborů záhlaví. Tyto duplicitní definice způsobují chyby kompilátoru. Této problematické situaci lze předejít pomocí mechanismu zvaného header guard, což jsou direktivy podmíněné kompilace, jak je ukázáno níže.
#ifndef ANY_UNIQUE_NAME_HERE
#define ANY_UNIQUE_NAME_HERE
// your declarations (and certain types of definitions) here
#endif
Pomocí této hlavičky preprocesor zkontroluje, zda již bylo definováno ANY_UNIQUE_NAME_HERE
. Pokud je záhlaví opakovaně zahrnuto do stejného souboru, obsah záhlaví bude ignorován.
Příklad souboru H
// sample.h
#pragma once
#include <vector> // #include directive
#include <string>
namespace N // namespace declaration
{
inline namespace P
{
//...
}
enum class colors : short { red, blue, purple, azure };
const double PI = 3.14; // const and constexpr definitions
constexpr int MeaningOfLife{ 42 };
constexpr int get_meaning()
{
static_assert(MeaningOfLife == 42, "unexpected!"); // static_assert
return MeaningOfLife;
}
using vstr = std::vector<int>; // type alias
extern double d; // extern variable
#define LOG // macro definition
#ifdef LOG // conditional compilation directive
void print_to_log();
#endif
class my_class // regular class definition,
{ // but no non-inline function definitions
friend class other_class;
public:
void do_something(); // definition in my_class.cpp
inline void put_value(int i) { vals.push_back(i); } // inline OK
private:
vstr vals;
int i;
};
struct RGB
{
short r{ 0 }; // member initialization
short g{ 0 };
short b{ 0 };
};
template <typename T> // template definition
class value_store
{
public:
value_store<T>() = default;
void write_value(T val)
{
//... function definition OK in template
}
private:
std::vector<T> vals;
};
template <typename T> // template declaration
class value_widget;
}