zoukankan      html  css  js  c++  java
  • 指针的指针和指针的引用

    展示一下使用指针的指针和指针的引用修改传递给方法的指针,以便更好的使用它。(这里说的指针的指针不是一个二维数组)

    为什么需要使用它们

    当我们把一个指针做为参数传一个方法时,其实是把指针的复本传递给了方法,也可以说传递指针是指针的值传递。

    如果我们在方法内部修改指针会出现问题,在方法里做修改只是修改的指针的copy而不是指针本身,原来的指针还保留着原来

    的值。我们用下边的代码说明一下问题

    int m_value = 1;
    
    void func(int *p)
    {
        p = &m_value;
    }
    
    int main(int argc, char *argv[])
    {
        int n = 2;
        int *pn = &n;
        cout << *pn << endl;
        func(pn);
        cout << *pn <<endl;
        return 0;
    }

    int m_value = 1;
    
    void func(int **p)
    {
        *p = &m_value;
        *p = new int(4);
    }
    
    
     int main(){
        int n = 2;
        cout<<&m_value<<endl;
        int *pn = &n;
        cout << *pn << endl;
        func(&pn);
        cout << *pn <<endl;
        cout<<pn<<endl;
        system("pause");
     }
    --------------

    012B7000
    2
    4
    008F81A0

    ---------------

    
    
    int m_value = 1;
    
    void func(int **p)
    {
        *p = &m_value;
        //*p = new int(4);
    }
    
    
     int main(){
        int n = 2;
        cout<<&m_value<<endl;
        int *pn = &n;
        cout << *pn << endl;
        func(&pn);
        cout << *pn <<endl;
        cout<<pn<<endl;
        system("pause");
     }
    
    

    00A17000
    2
    1
    00A17000

     

    我们看一下 func(int **p)这个方法

    
    
    • p:  是一个指针的指针,在这里我们不会去对它做修改,否则会丢失这个指针指向的指针地址
    • *p:  是被指向的指针,是一个地址。如果我们修改它,修改的是被指向的指针的内容。换句话说,我们修改的是main()方法里 *pn指针
    • **p: 两次解引用是指向main()方法里*pn的内容
    
    
    int m_value = 1;
    
    void func(int *&p)
    {
        p = &m_value;
    
        // 也可以根据你的需求分配内存
        p = new int;
        *p = 5;
    }
    
    int main(int argc, char *argv[])
    {
        int n = 2;
        int *pn = &n;
        cout << *pn << endl;
        func(pn);
        cout << *pn <<endl;
        return 0;
    }
    
    

    看一下func(int *&p)方法

    • p:  是指针的引用,main()方法里的 *pn
    • *p:是main()方法里的pn指向的内容。
     
  • 相关阅读:
    赫夫曼树相关算法
    用栈来实现 括号匹配 字符序列检验
    二叉树的建立和遍历
    数据结构-算术表达式求值
    构造一个单链表L,其头结点指针为head,编写程序实现将L逆置
    单链表的基本操作(C语言)数据结构
    java代码打印杨辉三角
    无标题
    写一个方法,判断给定的数字是偶数还是奇数
    关于生物信息学与R的相关资料和网站
  • 原文地址:https://www.cnblogs.com/yxzfscg/p/4527864.html
Copyright © 2011-2022 走看看