• 笔试题


    写出如下程序运行结果:

    1. #include<stdio.h>  
    2. #include<string.h>  
    3. int main()  
    4. {  
    5.     int a[2000];  
    6.     char *p = (char*)a;  
    7.     forint i = 0; i < 2000; i++)  
    8.         a[i] = -1 - i;  
    9.     printf( "%d\n", strlen(p));  
    10.     return 0;  
    11. }  


    请不要运行,先用草稿纸算算,能算出来不?

        此乃网速科技2011校园招聘笔试题第一题,本人心里素质很不错,不过看到此题当时就懵了,哪有人这么写代码的,所以当时也没有做出来,后来运行以后也没有搞懂,刚刚吃饭,突然就明白了,特此记录、分享之。废话不多说,运行结果是:

    1020

     

    解析:

        首先要明白负数在内存中的存储方式,还要知道int和char各占几位(都是最基本的啦)。这里很容易知道:

    a[0] = -1  内存中应当是:11111111  11111111  11111111  11111111

    a[1] = -2  内存中应当是:11111111  11111111  11111111  11111110

    a[2] = -3  内存中应当是:11111111  11111111  11111111  11111101

    ……

    a[255] = -256 内存中应当是: 11111111 11111111 1111111100000000

    当程序计算strlen(p)的时候遇到8个0就停止了,所以是255 * 4 + 3 = 1023.

    为什么结果是1020呢?(PS:我的cpu是intel的,intel的cpu一般都是小端存储)这就涉及到内存的存储问题了。

     


    众所周知,内存存储分为大端小端,大端就是我们人类理解的这样,将高位写在前面,将地位写在后面,小端存储则正好相反,所以a[255] = -256 在内存中的表示形式是: 00000000 11111111 11111111 11111111,这就是为什么答案是1020。当然了不同的机器会有不同,如果笔试的时候注明一下,应该效果会更好。

     

    附判断大端小端的代码:

      1. #include<stdio.h>  
      2. int check()  
      3. {  
      4.     union check  
      5.     {  
      6.         int i;  
      7.         char ch;  
      8.     }c;  
      9.     printf("%d\n" , &c.i);  
      10.     printf("%d\n", &c.ch);  
      11.     c.i  =1;  
      12.     return (c.ch == 1);  
      13. }  
      14. int main()  
      15. {  
      16.     int ret;  
      17.     ret = check();  
      18.     if(ret == 1)  
      19.     {  
      20.         printf("little\n");  
      21.     }  
      22.     else  
      23.     {  
      24.         printf("Big\n");  
      25.           
      26.     }  
      27.     return 0;  
      28. }  
  • 相关阅读:
    常用jquery
    常用记录
    mysql proxy 读写分离
    Linux 学习笔记
    php 1116
    php 1115
    php 1110
    php 1109
    php 1108
    php 1105
  • 原文地址:https://www.cnblogs.com/herizai/p/3078419.html
Copyright © 2020-2023  润新知