• C语言中的 sizeof 问题


     1 #include <stdio.h>   
     2 #define NUM (sizeof(arr) / sizeof(arr[0]))   
     3   
     4 int arr[] = { 1234567 };  
     5   
     6 int main()  
     7 {  
     8     int i;  
     9    
    10     for( i = -1; i <= ( NUM - 2 ); i++)  
    11     {       
    12     printf("%d\n",arr[i+1]);  
    13     }  
    14       
    15     return 0;  
    16 }  

    输出的结果是什么呢?自己看看,是不是很“恶心”,很出乎意料!?

    竟然是空的!

    其实,不是空的才不正常呢!

    那么我们就需要知道 sizeof 的实现原理!

    我们要知道的是:sizeof返回的是一个unsinged int的值!那么在for循环的时候,i = -1就会向后面转型,将其值转化为sizeof的值,那么我们很清楚,-1转化的sizeof的值是很大的一个正整数!那么很显然就直接不符合i <= ( NUM - 2 )的条件了,所以就不会输出!!!

    那么sizeof还有另一个问题:

    看下面代码:

    #include <stdio.h>   
    int main()  
    {  
        int i;  
        i = 10;  
      
        printf("i : %d\n",i);  
        printf("sizeof(i++) is: %d\n",sizeof(i++));  
        printf("i : %d\n",i);  
      
        return 0;  
    }  

    知道结果是什么吗?

    结果在我的机子上的运行:

    pt@ubuntu:~/桌面/C语言中好玩的东东$ ./c

     i : 10
     sizeof(i++) is: 4
     i : 10

    为什么第三个还是输出10呢?!

    解释:

            解决这个问题就是要理解编译器编译原理
            我们要知道sizeof仅仅是一个操作符而已
            并不是函数,sizeof要做的仅仅是获得
            i++的字节数,那么所以在编译的时候
            就直接用4代替了i++了,反正编译器知道
            结果都是一样,所以最终i++并没有执行!

    还有什么更好的想法,欢迎大家共勉,呵呵呵~

  • 相关阅读:
    字,字节,字长,位的概念与区分
    Prim算法、Kruskal算法、Dijkstra算法
    关联容器
    各种排序算法的性能特点
    随机种子
    实参&形参
    C++中的I/O输入输出问题
    NLPIR智能KGB知识图谱引擎可视化数据挖掘
    NLPIR-KGB知识图谱引擎突破传统数据挖掘束缚
    NLPIR大数据语义系统KGB技术引领新方向
  • 原文地址:https://www.cnblogs.com/xyz123753/p/2610188.html
Copyright © 2020-2023  润新知