Among all the pre-processing commands, the # pragma command may be the most complex. It is used to set the compiler status or to instruct the compiler to complete some specific actions. # The Pragma command provides a method for each compiler to provide the unique features of the host or operating system while maintaining full compatibility with C and C ++ languages. According to the definition, the compilation instructions are proprietary to machines or operating systems and are different for each compiler. The format is generally: # pragma para Here, para is a parameter. Below are some common parameters. (1) Message parameter. The message parameter is one of my favorite parameters. It can be used in the compilation information output window. Output the corresponding information. Source code Information control is very important. The usage is as follows: # Pragma message ("message text ") When the compiler encounters this instruction, it prints the message text in the compilation output window. When we Program Defines many macros to control the source Code In versions, we may forget whether these macros are correctly set. In this case, we can use this command to check the macros during compilation. Suppose we want to determine whether we have defined the _ x86 macro in the source code. The following method can be used: # Ifdef _ x86 # Pragma message ("_ x86 macro activated !") # Endif After we define the _ x86 macro, the application will display "_ X86 macro activated !". We won't be scratching our heads because we don't remember some specific macros we defined. .
(2) The other Pragma parameter that is used more frequently is code_seg. Format: # Pragma code_seg (["section-name" [, "section-class"]) It can set the code segment where function code is stored in the program. It is used when we develop the driver.
(3) # pragma once (commonly used) You only need to add this command at the beginning of the header file to ensure that the header file is compiled once. This command is actually available in vc6, but it is not widely used in consideration of compatibility.
(4) # pragma hdrstop indicates that the pre-compiled header file ends here, and the subsequent header files are not pre-compiled. BCB can pre-compile the header file to speed up the link, but if all header files are pre-compiled, it may occupy too much disk space. Therefore, this option is used to exclude some header files. Sometimes there is a dependency between units. For example, unit a depends on unit B. Therefore, Unit B must be compiled before unit. You can use # pragma startup to specify the compilation priority. If # pragma package (smart_init) is used, BCB will be compiled based on the priority.
(5) # pragma resource "*. DFM" indicates adding resources in the *. DFM file to the project. * DFM includes the form The definition of the appearance.
(6) # pragma warning (Disable: 4507 34; once: 4385; error: 164) It is equivalent: # Pragma warning (Disable: 4507 34) // do not display the 4507 and 34 Warnings # Pragma warning (once: 4385) // only one warning message is reported once # Pragma warning (error: 164) // the error message 164 is used as an error. This pragma warning also supports the following formats: # Pragma warning (push [, N]) # Pragma warning (POP) Here N represents a warning level (1---4 ). # Pragma warning (push) saves the existing warning status of all warning information. # Pragma warning (push, n) saves the existing warning status of all warning information, and sets global warning The level is set to n. # Pragma warning (POP) pops up the last warning message to the stack. All changes are canceled. For example: # Pragma warning (push) # Pragma warning (Disable: 4705) # Pragma warning (Disable: 4706) # Pragma warning (Disable: 4707) //....... # Pragma warning (POP) At the end of the Code, save all warning information (including 4707, and ). (7) Pragma comment (...) This command puts a comment record into an object file or executable file. Common lib keywords can help us to connect to a library file. (8) Export DLL functions using Pragma
The traditional way to exit the DLL function is to use the module definition file (. def), Visual C ++ provides a more concise and convenient method, that is, the "_ declspec ()" keyword is followed by "dllexport", telling the connection to export this function, for example: _ Declspec (dllexport) int _ stdcall myexportfunction (INT itest ); Put "_ declspec (dllexport)" at the beginning of the function declaration, and connect the generated DLL to export the function "_ myexportfunction @ 4 ". The name of the export function above may not be what I want. We want to export the original "myexportfunction ". Fortunately, VC provides a pre-processing indicator "# pragma" to specify the connection options (not only this function, but also many indication functions), as follows: # Pragma comment (linker, "/export: myexportfunction = _ myexportfunction @ 4 ")
This is just like the hope of the day :). If you want to specify the export sequence, or export the function as the serial number without entryname, this preprocessing indicator (specifically the connector) can be implemented. Let's take a look at the msdn syntax description: /Export: entryname [, @ ordinal [, noname] [, Data] @ Ordinal specifies the order. noname indicates that only the function is exported as the serial number. The data keyword specifies that the export item is a data item. each compilation program can use the # pragma command to activate or terminate some compilation functions supported by the Compilation Program. For example, for loop optimization: # pragma loop_opt (on) // activate # pragma loop_opt (off) // terminate sometimes, some functions in the program may cause the compiler to send a warning that you are familiar with and want to ignore, such as "parameter XXX is never used in function XXX ", # pragma warn-100 // turn off the warning message for warning #100 int insert_record (REC * r) {/ * function body */} # pragma warn + 100 // turn the warning mesning E for warning #100 back on the function generates a warning message with a unique signature 100, so that the warning can be temporarily terminated. each compiler has different implementations for # pragma, and the effectiveness in one compiler is almost ineffective in other compilers. You can view it in the compiler documentation. |