Chinaunix首页 | 论坛 | 博客
  • 博客访问: 503770
  • 博文数量: 398
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 14
  • 用 户 组: 普通用户
  • 注册时间: 2013-08-21 16:02
个人简介

嵌入式屌丝

文章分类

全部博文(398)

文章存档

2013年(398)

我的朋友

分类:

2013-12-04 17:27:49

原文地址:#pragma 作者:C加加

    #pragma
 
    该预处理指令的作用是设定编译器的状态或者是指示编译器完成一些特定的动作。不同的编译器#pragma的使用也会有所不同。
 
  其格式一般为:        #pragma  Para 
  其中Para  为参数.
 
  (1)#pragma  message(“消息文本”)
 
    它能够在编译信息输出窗口中输出相应的信息,这对于源代码信息的控制是非常重要的。当编译器遇到这条指令时就在编译输出窗口中将消息文本打印出来。
 
  #ifdef  __DEBUG__
      #pragma  message(“Defined __DEBUG__”) 
  #endif
        
  (2)#pragma  code_seg(  ["section-name"[,"section-class"]  ]  ) 
 
  它能够设置程序中函数代码存放的代码段,开发驱动程序的时候就会使用到它。
 
  (3)#pragma  once  (比较常用) 
 
  只要在头文件的最开始加入这条指令就能够保证头文件被编译一次。  
      
  (4)#pragma  hdrstop
 
    表示预编译头文件到此为止,后面的头文件不进行预编译。预编译头文件可以加快链接的速度,但如果所有头文件都进行预编译又可能占太多磁盘空间,所以使用这个选项排除一些头文件。  
        
  (5)#pragma  resource  "*.dfm"表示把*.dfm文件中的资源加入工程。
        
  (6)#pragma  warning(  disable  :  4507  34;  once  :  4385;  error  :  164  )     等价于: 
  #pragma  warning(disable:4507  34)    //  不显示4507和34号警告信息 
  #pragma  warning(once:4385)                //  4385号警告信息仅报告一次 
  #pragma  warning(error:164)                //  把164号警告信息作为一个错误。
  同时这个pragma  warning  也支持如下格式: 
  #pragma  warning(  push  [  ,n  ]  ) 
  #pragma  warning(  pop  ) 
  这里n代表一个警告等级(1---4)。 
  #pragma  warning(  push  )保存所有警告信息的现有的警告状态。 
  #pragma  warning(  push,  n)保存所有警告信息的现有的警告状态,并且把全局警告等级设定为n。   
  #pragma  warning(  pop  )向栈中弹出最后一个警告信息,在入栈和出栈之间所作的一切改动取消。例如: 
  #pragma  warning(  push  ) 
  #pragma  warning(  disable  :  4705  ) 
  #pragma  warning(  disable  :  4706  ) 
  #pragma  warning(  disable  :  4707  ) 
  //....... 
  #pragma  warning(  pop  )   
  在这段代码的最后,重新保存所有的警告信息(包括4705,4706和4707)。
 
  (7)#pragma  comment(...)

    放置一个注释到对象文件或者可执行文件。

    #pragma comment( comment-type ,"commentstring"] )

comment-type是一个预定义的标识符,指定注释的类型,应该是compiler,exestr,lib,linker之一。commentstring是一个提供为comment-type提供附加信息的字符串.
1、compiler:放置编译器的版本或者名字到一个对象文件,该选项是被linker忽略的。
2、exestr:在以后的版本将被取消。
3、lib:放置一个库搜索记录到对象文件中,这个类型应该是和
commentstring(指定你要Liner搜索的lib的名称和路径)一起使用.这个库的名字放在目标文件的默认库搜索记录的后面,linker搜索这个这个库就像你在命令行输入这个命令一样。可以在一个源文件中设置多个库记录,它们在目标文件中的顺序和在源文件中的顺序一样。如果默认库和附加库的次序是需要区别的,使用Z编译开关是防止默认库放到目标模块。
4、linker:指定一个连接选项,这样就不用在命令行输入或者在开发环境中设置了。只有下面的linker选项能被传给Linker:
  • /DEFAULTLIB

  • /EXPORT

  • /INCLUDE

  • /MANIFESTDEPENDENCY

  • /MERGE

  • /SECTION

  •     (8)通过#pragma pack(n)改变C编译器的字节对齐方式。
     

      每个编译程序可以用#pragma指令激活或终止该编译程序支持的一些编译功能。例如,对循环优化功能: 
      #pragma  loop_opt(on)            //  激活 
      #pragma  loop_opt(off)    //  终止
      有时,程序中会有些函数会使编译器发出你熟知而想忽略的警告,如“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  message  for  warning 100  back  on 
      函数会产生一条有唯一特征码100的警告信息,如此可暂时终止该警告。 
      每个编译器对#pragma的实现不同,在一个编译器中有效在别的编译器中几乎无效。
     
    阅读(938) | 评论(0) | 转发(0) |
    给主人留下些什么吧!~~