zoukankan      html  css  js  c++  java
  • C++:const sizeof 及array的学习笔记

    #include <iostream>
    #include 
    <stdlib.h>

    using namespace std;

    ///////////////////////////////////////////////////////////
    void TestPointArray();
    //////////////////////////////////////////////////////////

    void TestConstRef()
    {
      
    int a = 100;
      
    const int &= a;
      cout
    <<b<<endl; // 100  
      a = 2;
      cout
    <<b<<endl;  // 2
      
    //  b = 1; // error
      const int &= 300;
      cout
    <<c<<endl;
    }


    void TestSizeof()
    {
      
    char s1[6= "ABCDE";
      
    char *s2 = "abcde";
      
    char s3[] = "abcde";
      
      cout
    <<sizeof(s1)<<endl; // 6
      cout<<sizeof(s2)<<endl; // 4
      cout<<sizeof(s3)<<endl; // 6
    }


    void TestArray()
    {
      
    int a[] = {12345};
      
    int *= a;
      
      cout
    <<p<<endl; // 0x22ff50
      cout<<*p++<<endl;
      cout
    <<p<<endl; // ?
      cout<<- a<<endl; // ?
      cout<<*++p<<endl; // 3
      cout<<*(p + 1)<<endl;
      cout
    <<*((int*)((char *)p + 1))<<endl; // 哈哈, 是 0x4000 
    }


    void TestArrPara(int a[5])
    {
      cout
    << *(a++)<<endl; // OK
    }


    int main(int argc, char *argv[])
    {
    //  TestConstRef();
    //  TestSizeof(); 
    //  TestArray();
      
      
    int a[] = {12345};
    //  TestArrPara(a);
      TestPointArray();
      
      system(
    "PAUSE");    
      
    return 0;
    }



    void TestPointArray()
    {
      
    int a[] = {12345};
      
    int (*p)[5];
      p 
    = &a;
      cout
    <<*p[0]<<endl;
      cout
    <<*p[1]<<endl;
      cout
    <<*p[2]<<endl;
      cout
    <<*p[3]<<endl;
      cout
    <<*p[4]<<endl;

      cout
    <<endl;
      cout
    <<(*p)[0]<<endl;
      cout
    <<(*p)[1]<<endl;
      cout
    <<(*p)[2]<<endl;
      cout
    <<(*p)[3]<<endl;
      cout
    <<(*p)[4]<<endl;

      cout
    <<endl;
      cout
    <<p[0]<<endl;
      cout
    <<p[1]<<endl;
      cout
    <<p[2]<<endl;
      cout
    <<p[3]<<endl;
      cout
    <<p[4]<<endl;
      
      cout
    <<endl;
      cout
    <<+ 0<<endl;
      cout
    <<+ 1<<endl;
      cout
    <<+ 2<<endl;
      cout
    <<+ 3<<endl;
      cout
    <<+ 4<<endl;
      
      cout
    <<endl;
      
    int *= *p;
      cout
    << *++q<<endl;

    }

  • 相关阅读:
    POJ1611 && POJ2524 并查集入门
    POJ 2785:4 Values whose Sum is 0 二分
    POJ 2309:BST lowbit
    POJ 3692:Kindergarten 求补图的最大点独立集 头一次接触这样的做法
    POJ 3735:Training little cats 联想到矩阵相乘
    POJ 3916:Duplicate Removal 将相近的重复元素删除
    nyoj43--24 Point game(dfs)
    cf-Igor In the Museum (dfs)
    8VC Venture Cup 2016 -- Elimination Round Tutorial 626B
    蓝桥杯
  • 原文地址:https://www.cnblogs.com/qkhh/p/1038938.html
Copyright © 2011-2022 走看看