C ++ Preprocessor

Praprosesor adalah arahan, yang memberikan instruksi kepada kompilator untuk memproses informasi sebelum kompilasi sebenarnya dimulai.

Semua arahan preprocessor dimulai dengan #, dan hanya karakter spasi yang boleh muncul sebelum arahan preprocessor pada sebuah baris. Direktif preprocessor bukanlah pernyataan C ++, jadi tidak diakhiri dengan titik koma (;).

Anda sudah melihat file #includedirektif di semua contoh. Makro ini digunakan untuk menyertakan file header ke dalam file sumber.

Ada sejumlah arahan preprocessor yang didukung oleh C ++ seperti #include, #define, #if, #else, #line, dll. Mari kita lihat arahan penting -

#Define Preprocessor

Perintah #define preprocessor membuat konstanta simbolis. Konstanta simbolis disebut amacro dan bentuk umum dari perintah tersebut adalah -

#define macro-name replacement-text

Ketika baris ini muncul di file, semua kejadian makro berikutnya di file itu akan diganti dengan teks pengganti sebelum program dikompilasi. Misalnya -

#include <iostream>
using namespace std;

#define PI 3.14159

int main () {
   cout << "Value of PI :" << PI << endl; 

   return 0;
}

Sekarang, mari kita lakukan preprocessing kode ini untuk melihat hasilnya dengan asumsi kita memiliki file kode sumber. Jadi mari kita kompilasi dengan opsi -E dan arahkan hasilnya ke test.p. Sekarang, jika Anda memeriksa test.p, itu akan memiliki banyak informasi dan di bagian bawah, Anda akan menemukan nilai yang diganti sebagai berikut -

$gcc -E test.cpp > test.p

...
int main () {
   cout << "Value of PI :" << 3.14159 << endl; 
   return 0;
}

Makro Seperti Fungsi

Anda dapat menggunakan #define untuk menentukan makro yang akan mengambil argumen sebagai berikut -

#include <iostream>
using namespace std;

#define MIN(a,b) (((a)<(b)) ? a : b)

int main () {
   int i, j;
   
   i = 100;
   j = 30;
   
   cout <<"The minimum is " << MIN(i, j) << endl;

   return 0;
}

Jika kita mengkompilasi dan menjalankan kode di atas, ini akan menghasilkan hasil sebagai berikut -

The minimum is 30

Kompilasi Bersyarat

Ada beberapa arahan, yang dapat digunakan untuk mengkompilasi bagian selektif dari kode sumber program Anda. Proses ini disebut kompilasi bersyarat.

Konstruksi preprosesor bersyarat sangat mirip dengan struktur pemilihan 'jika'. Perhatikan kode preprocessor berikut -

#ifndef NULL
   #define NULL 0
#endif

Anda dapat mengkompilasi program untuk tujuan debugging. Anda juga dapat mengaktifkan atau menonaktifkan debugging menggunakan makro tunggal sebagai berikut -

#ifdef DEBUG
   cerr <<"Variable x = " << x << endl;
#endif

Ini menyebabkan cerrpernyataan yang akan dikompilasi dalam program jika DEBUG simbolik konstan telah didefinisikan sebelum direktif #ifdef DEBUG. Anda dapat menggunakan pernyataan #if 0 untuk mengomentari sebagian program sebagai berikut -

#if 0
   code prevented from compiling
#endif

Mari kita coba contoh berikut -

#include <iostream>
using namespace std;
#define DEBUG

#define MIN(a,b) (((a)<(b)) ? a : b)

int main () {
   int i, j;
   
   i = 100;
   j = 30;

#ifdef DEBUG
   cerr <<"Trace: Inside main function" << endl;
#endif

#if 0
   /* This is commented part */
   cout << MKSTR(HELLO C++) << endl;
#endif

   cout <<"The minimum is " << MIN(i, j) << endl;

#ifdef DEBUG
   cerr <<"Trace: Coming out of main function" << endl;
#endif

   return 0;
}

Jika kita mengkompilasi dan menjalankan kode di atas, ini akan menghasilkan hasil sebagai berikut -

The minimum is 30
Trace: Inside main function
Trace: Coming out of main function

Operator # dan ##

Operator praprosesor # dan ## tersedia dalam C ++ dan ANSI / ISO C. Operator # menyebabkan token teks pengganti diubah menjadi string yang diapit oleh tanda kutip.

Pertimbangkan definisi makro berikut -

#include <iostream>
using namespace std;

#define MKSTR( x ) #x

int main () {

   cout << MKSTR(HELLO C++) << endl;

   return 0;
}

Jika kita mengkompilasi dan menjalankan kode di atas, ini akan menghasilkan hasil sebagai berikut -

HELLO C++

Mari kita lihat cara kerjanya. Sangat mudah untuk dipahami bahwa preprocessor C ++ mengubah jalur -

cout << MKSTR(HELLO C++) << endl;

Baris di atas akan diubah menjadi baris berikut -

cout << "HELLO C++" << endl;

Operator ## digunakan untuk menggabungkan dua token. Ini contohnya -

#define CONCAT( x, y )  x ## y

Saat CONCAT muncul di program, argumennya digabungkan dan digunakan untuk menggantikan makro. Misalnya, CONCAT (HELLO, C ++) diganti dengan "HELLO C ++" dalam program sebagai berikut.

#include <iostream>
using namespace std;

#define concat(a, b) a ## b
int main() {
   int xy = 100;
   
   cout << concat(x, y);
   return 0;
}

Jika kita mengkompilasi dan menjalankan kode di atas, ini akan menghasilkan hasil sebagai berikut -

100

Mari kita lihat cara kerjanya. Sangat mudah untuk memahami bahwa preprocessor C ++ mengubah -

cout << concat(x, y);

Baris di atas akan diubah menjadi baris berikut -

cout << xy;

Makro C ++ standar

C ++ menyediakan sejumlah makro yang telah ditentukan sebelumnya yang disebutkan di bawah -

Sr Tidak Makro & Deskripsi
1

__LINE__

Ini berisi nomor baris program saat ini ketika sedang dikompilasi.

2

__FILE__

Ini berisi nama file program saat ini ketika sedang dikompilasi.

3

__DATE__

Ini berisi string berbentuk bulan / hari / tahun yang merupakan tanggal penerjemahan file sumber menjadi kode objek.

4

__TIME__

Ini berisi string dalam format jam: menit: detik yang merupakan waktu saat program dikompilasi.

Mari kita lihat contoh untuk semua makro di atas -

#include <iostream>
using namespace std;

int main () {
   cout << "Value of __LINE__ : " << __LINE__ << endl;
   cout << "Value of __FILE__ : " << __FILE__ << endl;
   cout << "Value of __DATE__ : " << __DATE__ << endl;
   cout << "Value of __TIME__ : " << __TIME__ << endl;

   return 0;
}

Jika kita mengkompilasi dan menjalankan kode di atas, ini akan menghasilkan hasil sebagai berikut -

Value of __LINE__ : 6
Value of __FILE__ : test.cpp
Value of __DATE__ : Feb 28 2011
Value of __TIME__ : 18:52:48