Po co włączać te same nagłówki w wielu plikach cpp, a potem działa ich kompilacja? [duplikować]

To pytanie ma już tutaj odpowiedź:

Jedna reguła definicji i różne definicje klas w dwóch jednostkach tłumaczeniowych 1 odpowiedź

Na przykład mam 2 pliki cpp: f1.cpp i f2.cpp, a także plik nagłówkowy: xxx.h.

f1.cpp ma następujący kod źródłowy:

#include <iostream>
#include "xxx.h"

using namespace std;

int main ()
{
    rect rplace;
    polar pplace;
    cout<<"Enter the x and y values: ";
    while (cin>>rplace.x>>rplace.y)
    {
        pplace=rect_to_polar(rplace);
        show_polar(pplace);
        cout<<"Next two numbers (q to quit): ";
    }
    cout<<"Done.\n";
    return 0;
}

kod źródłowy f2.cpp:

#include <iostream>
#include <cmath>
#include "xxx.h"

polar rect_to_polar (rect xypos)
{
    using namespace std;
    polar answer;
    answer.distance=sqrt(xypos.x*xypos.x+xypos.y*xypos.y);
    answer.angle=atan2(xypos.y, xypos.x);
    return answer;
} 

void show_polar (polar dapos)
{
    using namespace std;
    const double Rad_to_deg=57.29577951;
    cout<<"distance="<<dapos.distance;
    cout<<", angle= "<<dapos.angle*Rad_to_deg;
    cout<<"degrees\n";
}

I xxx.h:

struct polar
{
    double distance;
    double angle;
};

struct rect
{
    double x;
    double y;
};

polar rect_to_polar (rect xypos);
void show_polar(polar dapos);

Myślałem, że powinien wystąpić błąd kompilatora, ponieważ nagłówkixxx.h iiostream są uwzględniane dwa razy: raz w f1.cpp i raz w f2.cpp. Ale wszystko zostało skompilowane, więc nie rozumiem, jak to działa.

questionAnswers(1)

yourAnswerToTheQuestion