zoukankan      html  css  js  c++  java
  • 注意区别二位数组和二维指针

    int a[][4];

    int *a[4];

    int ** a;

    int (*a)[4];

    注意这四种情况,搞懂这四种情况,就基本没问题了。 

     转自:http://www.cnblogs.com/chenbin7/archive/2011/10/03/2198675.html

    #include <iostream> 
    using namespace std; 
     
    int main(int argc, char* argv[]) 

        int arr1[3]; 
        int arr2[3]; 
        int arr3[3]; 
        int * ptr; 
        // ptr1是一个指向 int [3] 的指针,即ptr的类型和&arr1的类型是一样的,注意:arr1指向的内存区域定长 
        int ptr1[3][3]={{1,2,3},{1,2,3},{1,2,3}}; 
        // ptr2是一个指向 int * 的指针,即ptr2的类型和&ptr是一样的,注意:ptr指向的内存区域不定长 
        int * ptr2[3]={arr1,arr2,arr3}; 
        // ptr3是一个指向 int [3] 的指针,即ptr3的类型和&arr1的类型是一样的,注意:arr1指向的内存区域定长 
        int(* ptr3)[3]=&arr1; 
        ptr3=ptr1; // 没错,他们的类型相同 
        
    // ptr3=ptr2;//error 无法从“int *[3]”转换为“int (*)[3] 
        
    // ptr4是一个指向 int * 的指针,即ptr4的类型和&ptr是一样的,注意:ptr指向的内存区域不定长 
        int ** ptr4; 
        //ptr4=&arr1; //error 无法从“int (*)[3]”转换为“int ** 
        ptr4=ptr2; // 没错,他们的类型相同 
        
    //ptr4=ptr3; // error 无法从“int (*)[3]”转换为“int ** 
        return 0; }

     

  • 相关阅读:
    TSQL 常用日期格式
    TSQL数据类型研究_tinyint
    设置数据库状态
    判断存储过程、触发器、视图是否存在并删除
    TSQL日期函数
    TSQL常用日期函数
    TSQL单双引号分隔符相关
    动态存储过程
    TSQL类型转换函数
    modelsim保存仿真结果,以及打开保存的仿真结果的波形wlf文件(经过实验,真实可用)
  • 原文地址:https://www.cnblogs.com/jilichuan/p/4004569.html
Copyright © 2011-2022 走看看