Препроцессоры вставляют файлы как целиком, так и частично, в зависимости от того, как используется директива #include.
Директива #include используется для включения содержимого другого файла в исходный код программы. Когда препроцессор встречает директиву #include, он заменяет ее содержимое содержимым указанного файла.
Использование символов <> или "" вокруг имени файла в директиве #include определяет способ поиска файла для вставки. Если используются "<>" символы, то файл будет искаться в системном каталоге, таком как /usr/include в Unix-подобных системах. Если используются "" символы, то файл будет искаться сначала в текущем каталоге, а затем в других указанных каталогах.
Когда файл вставляется через #include, он вставляется целиком. Весь его текст считывается и вставляется на место директивы #include в исходном коде. Результатом этой операции становится промежуточный исходный код, который затем будет обрабатываться компилятором.
Однако, в случае циклических зависимостей, когда файл A включает файл B, а файл B включает файл A, может возникнуть проблема бесконечной рекурсии. Чтобы предотвратить это, препроцессор использует механизм заголовочных файлов с условиями включения. Таким образом, при использовании директивы #include в коде, можно указать условия, при которых файл будет вставлен (например, только один раз) или не будет вставлен вообще.
Еще одна особенность препроцессоров заключается в том, что они выполняют вставку файлов и обработку директив #include до самой компиляции. Это означает, что препроцессор не обрабатывает код на языке программирования, а только текстовые файлы, вставляя их содержимое в исходный код.
Таким образом, препроцессоры вставляют файлы как целиком, так и частично, при этом определяя условия, при которых файлы вставляются или не вставляются в код программы. Это позволяет разрабатывать более организованный и модульный код, упрощая процесс разработки и поддержки программного обеспечения.