不同编译器返回不同类型

/*------------ miscellaneous -----------------------------------------------*/

/**
 * Linkage specification macro
 */
#if !defined(PTAPI_DLL)
 #if defined(BUILD_PTAPI_DLL)
  #if defined(_MSC_VER)
            #if defined(PTAPI_STATIC)
                #if defined __cplusplus
                    #define PTAPI_DLL extern "C"
                #else
                    #define PTAPI_DLL
                #endif
            #else
                #if defined __cplusplus
                    #define PTAPI_DLL extern "C"
                #else
                    #define PTAPI_DLL extern
                #endif
            #endif
  #elif defined(__SYMBIAN32__)
   #if defined(__cplusplus)
    #define PTAPI_DLL extern"C" EXPORT_C
   #else
    #define PTAPI_DLL EXPORT_C
   #endif
  #else
   #if defined(__cplusplus)
    #define PTAPI_DLL extern"C"
   #else
    #define PTAPI_DLL
   #endif
  #endif
 #else
  #if defined(_MSC_VER)
            #if defined(PTAPI_STATIC)
                #if defined __cplusplus
                    #define PTAPI_DLL extern "C"
                #else
                    #define PTAPI_DLL
                #endif
            #else   
       #if defined __cplusplus
        #define PTAPI_DLL extern "C" __declspec(dllimport)
       #else
        #define PTAPI_DLL __declspec(dllimport)
       #endif
            #endif
  #elif defined(__SYMBIAN32__)
   #if defined(__cplusplus)
    #define PTAPI_DLL extern"C" IMPORT_C
   #else
    #define PTAPI_DLL IMPORT_C
   #endif
  #else
   #if defined(__cplusplus)
    #define PTAPI_DLL extern"C"
   #else
    #define PTAPI_DLL
   #endif
  #endif
 #endif
#endif

 

/**
 * Macro for standard call convention
 */
#ifndef PTAPI
#if defined(_MSC_VER)
#if defined(_DOS)
#define PTAPI far
#else
#define PTAPI __stdcall
#endif
#else
#define PTAPI
#endif
#endif

 

/*
nothing doing macros used for better documenting parameter specification
*/

/**
 * This is a definition which has sole purpose of
 * helping readability.  It indicates that formal
 * parameter is an input parameter.
 */
#ifndef IN
#define IN
#endif

/**
 * This is a definition which has sole purpose of
 * helping readability.  It indicates that formal
 * parameter is an output parameter. 
 */
#ifndef OUT
#define OUT
#endif

/**
 * This is a definition which has sole purpose of
 * helping readability.  It indicates that formal
 * parameter is both input and output parameter. 
 */
#ifndef INOUT
#define INOUT
#endif

/**
 * This is a definition which has sole purpose of
 * helping readability.  It indicates that formal
 * parameter is an optional parameter. 
 */
#ifndef OPTIONAL
#define OPTIONAL
#endif


某个.h文件中有这样一段

 

然后.c文件中有PTAPI_DLL  PT_STATUS  PTAPI  PTOpen(。。形参。。。){。函数体。。}

 

经查定义处发现PTAPI_DLL  PT_STATUS  PTAPI只有一个是被定义成long型,其他的均定义为空。经请教别人得知,是为了在不同编译器下返回不同的值。PTAPI_DLL  PT_STATUS  PTAPI只有一个是有效的。

### C++ 返回类型时的编译器优化 当涉及到返回类型的场景,在C++中,编译器可以应用多种技术来减少不必要的对象复制开销。对于这类情况下的编译器优化,主要依赖于特定的编译选项以及编译器自身的特性。 #### 编译优化级别影响 不同的编译优化等级会影响编译器处理返回类实例的方式。较低级别的优化(如`-O0`)可能不会尝试消除临时对象或简化表达式[^4]。然而随着优化级别的提升至`-O2`或更高,编译器更积极地运用诸如命名返回优化(NRVO, Named Return Value Optimization)、RVO (Return Value Optimization) 和移动语义等机制来提高效率。 ```cpp class LargeObject { public: int data[100]; }; LargeObject create() { LargeObject obj; // 初始化... return obj; // 可能触发 RVO 或 NRVO } ``` #### 启用高级优化功能 为了进一步增强涉及复杂数据结构操作(包括但不限于返回大对象的情况),可以通过指定更高的优化标志如`-O3`甚至`-Ofast`让编译器尽可能多地实施性能改进措施。这些较高的优化层次不仅限于基本指令调度和寄存器分配,还包括: - **内联展开**:将小型函数直接嵌入调用处而非通过栈帧跳转执行; - **循环变换**:调整迭代逻辑以更好地适应硬件特点; - **向量指令生成**:利用SIMD扩展加速批量计算过程; 得注意的是,虽然高阶优化能够带来显著的速度增益,但也可能导致最终二进制文件体积增大,并且有时会使程序行为偏离严格的ISO/IEC标准定义。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值