sizeof()的实现.

今天群里讨论了sizeof()函数的实现.下面用了两个宏实现了这功能.
  1. #define w_sizeof_a(T) ( ( long )( ( T* )0 + 1 ) ) 
  2. #define w_sizeof_b(T) ( ( long )( &T + 1 ) - ( long )&T )  
  3. #include <iostream>
  4. using namespace std;
  5. int main()
  6. {
  7.     int a[100][100][10];
  8.     cout<<w_sizeof_a(int)<<endl;
  9.     cout<<w_sizeof_a(int*)<<endl;
  10.     cout<<w_sizeof_a(char)<<endl;
  11.     cout<<w_sizeof_a(float)<<endl;
  12.     cout<<w_sizeof_a(double)<<endl;
  13.     cout<<w_sizeof_b(a)<<endl;
  14.     return 0;
  15. }

实现是利用了指针加一,跳过的字节数来实现.

SECTIONS { CORE_SEC(.rodata) : FLAGS(arl) { *(.rodata.farConst.cpu0.32bit) *(.rodata.farConst.cpu0.16bit) *(.rodata.farConst.cpu0.8bit) *(.rodata) *(.rodata.*) *(.gnu.linkonce.r.*) /* * Create the clear and copy tables that tell the startup code * which memory areas to clear and to copy, respectively. */ . = ALIGN(4); PROVIDE(__clear_table = .); LONG(0 + ADDR(.CPU2.zbss)); LONG(SIZEOF(.CPU2.zbss)); LONG(0 + ADDR(.CPU2.bss)); LONG(SIZEOF(.CPU2.bss)); LONG(0 + ADDR(.CPU2.lmubss)); LONG(SIZEOF(.CPU2.lmubss)); LONG(0 + ADDR(.CPU1.zbss)); LONG(SIZEOF(.CPU1.zbss)); LONG(0 + ADDR(.CPU1.bss)); LONG(SIZEOF(.CPU1.bss)); LONG(0 + ADDR(.CPU1.lmubss)); LONG(SIZEOF(.CPU1.lmubss)); LONG(0 + ADDR(.CPU0.zbss)); LONG(SIZEOF(.CPU0.zbss)); LONG(0 + ADDR(.CPU0.bss)); LONG(SIZEOF(.CPU0.bss)); LONG(0 + ADDR(.CPU0.lmubss)); LONG(SIZEOF(.CPU0.lmubss)); LONG(0 + ADDR(.zbss)); LONG(SIZEOF(.zbss)); LONG(0 + ADDR(.sbss)); LONG(SIZEOF(.sbss)); LONG(0 + ADDR(.bss)); LONG(SIZEOF(.bss)); LONG(0 + ADDR(.lmubss)); LONG(SIZEOF(.lmubss)); LONG(0 + ADDR(.OS_STACK_OSCORE_CORE0)); LONG(SIZEOF(.OS_STACK_OSCORE_CORE0)); LONG(0 + ADDR(.OS_STACK_OSCORE_CORE1)); LONG(SIZEOF(.OS_STACK_OSCORE_CORE1)); LONG(0 + ADDR(.OS_GLOBAL_NOCACHE_VAR)); LONG(SIZEOF(.OS_GLOBAL_NOCACHE_VAR)); LONG(-1); LONG(-1); PROVIDE(__clear_table_dlmu = .); LONG(0 + ADDR(.sbss4)); LONG(SIZEOF(.sbss4)); LONG(-1); LONG(-1); PROVIDE(__clear_table_powerOn = .); LONG(0 + ADDR(.zbss_powerOn)); LONG(SIZEOF(.zbss_powerOn)); LONG(-1); LONG(-1); PROVIDE(__copy_table = .); LONG(LOADADDR(.CPU2.zdata)); LONG(0 + ADDR(.CPU2.zdata)); LONG(SIZEOF(.CPU2.zdata)); LONG(LOADADDR(.CPU2.data)); LONG(0 + ADDR(.CPU2.data)); LONG(SIZEOF(.CPU2.data)); LONG(LOADADDR(.CPU2.lmudata)); LONG(0 + ADDR(.CPU2.lmudata)); LONG(SIZEOF(.CPU2.lmudata)); LONG(LOADADDR(.CPU1.zdata)); LONG(0 + ADDR(.CPU1.zdata)); LONG(SIZEOF(.CPU1.zdata)); LONG(LOADADDR(.CPU1.data)); LONG(0 + ADDR(.CPU1.data)); LONG(SIZEOF(.CPU1.data)); LONG(LOADADDR(.CPU1.lmudata)); LONG(0 + ADDR(.CPU1.lmudata)); LONG(SIZEOF(.CPU1.lmudata)); LONG(LOADADDR(.CPU0.zdata)); LONG(0 + ADDR(.CPU0.zdata)); LONG(SIZEOF(.CPU0.zdata)); LONG(LOADADDR(.CPU0.data)); LONG(0 + ADDR(.CPU0.data)); LONG(SIZEOF(.CPU0.data)); LONG(LOADADDR(.CPU0.lmudata)); LONG(0 + ADDR(.CPU0.lmudata)); LONG(SIZEOF(.CPU0.lmudata)); LONG(LOADADDR(.zdata)); LONG(0 + ADDR(.zdata)); LONG(SIZEOF(.zdata)); LONG(LOADADDR(.sdata)); LONG(0 + ADDR(.sdata)); LONG(SIZEOF(.sdata)); LONG(LOADADDR(.data)); LONG(0 + ADDR(.data)); LONG(SIZEOF(.data)); LONG(LOADADDR(.lmudata)); LONG(0 + ADDR(.lmudata)); LONG(SIZEOF(.lmudata)); LONG(LOADADDR(.sdata4)); LONG(0 + ADDR(.sdata4)); LONG(SIZEOF(.sdata4)); LONG(LOADADDR(.CPU0.psram_text)); LONG(0 + ADDR(.CPU0.psram_text)); LONG(SIZEOF(.CPU0.psram_text)); LONG(LOADADDR(.CPU1.psram_text)); LONG(0 + ADDR(.CPU1.psram_text)); LONG(SIZEOF(.CPU1.psram_text)); LONG(LOADADDR(.CPU2.psram_text)); LONG(0 + ADDR(.CPU2.psram_text)); LONG(SIZEOF(.CPU2.psram_text)); LONG(LOADADDR(.FLSLOADERRAM2CODE)); LONG(0 + ADDR(.FLSLOADERRAM2CODE)); LONG(SIZEOF(.FLSLOADERRAM2CODE)); LONG(LOADADDR(.data_xcp)); LONG(0 + ADDR(.data_xcp)); LONG(SIZEOF(.data_xcp)); LONG(LOADADDR(.data_xcp_Fake)); LONG(0 + ADDR(.data_xcp_Fake)); LONG(SIZEOF(.data_xcp_Fake)); LONG(LOADADDR(.CPU0.slow_data)); LONG(0 + ADDR(.CPU0.slow_data)); LONG(SIZEOF(.CPU0.slow_data)); LONG(LOADADDR(.CPU1.slow_data)); LONG(0 + ADDR(.CPU1.slow_data)); LONG(SIZEOF(.CPU1.slow_data)); LONG(LOADADDR(.OS_GLOBAL_NOCACHE_INITVAR)); LONG(0 + ADDR(.OS_GLOBAL_NOCACHE_INITVAR)); LONG(SIZEOF(.OS_GLOBAL_NOCACHE_INITVAR)); LONG(-1); LONG(-1); LONG(-1); PROVIDE(__copy_table_dlmu = .); LONG(-1); LONG(-1); LONG(-1); PROVIDE(__copy_table_powerOn = .); LONG(LOADADDR(.zdata_powerOn)); LONG(0 + ADDR(.zdata_powerOn)); LONG(SIZEOF(.zdata_powerOn)); LONG(-1); LONG(-1); LONG(-1); . = ALIGN(8); }> default_rom }
最新发布
09-29
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值