很想搞清句柄,对象的引用,指向对象的指针的关系,就是各种函数的参数具体指什么?他们之间如何转换?

解决方案 »

  1.   

    有一种比喻是:引用就是对象的别名,所有对他的操作就是对 对象本身,
    就象你叫“李非”,而有人给你起个绰号叫“神腿李”,
    然后有人骂“神腿李”当然就是在骂你,所以要找他拼命,初始化引用首先要有被引用的对象存在,否则....&*&%^%%..但是在传递参数时,引用传递的本质与指针相同,传递的都是变量的地址,因为在另外一个函数内,要想引用一个变量,必须得到他的地址,才能对之进行操作总之:引用与指针本质是相同的,对引用的操作就等于对被引用变量的操作
      

  2.   

    句柄用来引用不同的windows对象。你可以对窗口、文件使用句柄,也能对分配了的内存、图象使用句柄。可以把句柄理解为与指针类似。你必须通过某种方式来创建句柄;而且在使用完后销毁掉,不然将造成资源泄漏而使你的系统瘫痪。所以要保证它们在某个时候被销毁了。句柄术语一般用来指获取另一个对象的方法——一个广义的假指针。这个术语是(故意的)含糊不清的。 含糊不清在实际中的某些情况下是有用的。例如,在早期设计时,你可能不准备用句柄来表示。你可能不确定是否将一个简单的指针或者引用或者指向指针的指针或者指向引用的指针或者整型标识符放在一个数组或者字符串(或其它键)以便能够以哈希表(hash-table)(或其他数据结构)或数据库键或者一些其它的技巧来查询。如果你只知道你会需要一些唯一标识的东西来获取对象,那么这些东西就被称为句柄。 因此,如果你的最终目标是要让代码唯一的标识/查询一个Fred类的指定的对象的话,你需要传递一个Fred句柄这些代码。句柄可以是一个能被作为众所周知的查询表中的键(key)来使用的字符串(比如,在std::map<std::string,Fred> 或 std::map<std::string,Fred*>中的键),或者它可以是一个作为数组中的索引的整数(比如,Fred* array = new Fred[maxNumFreds]),或者它可以是一个简单的 Fred*,或者它可以是其它的一些东西。
    初学者常常考虑指针,但实际上使用未初始化的指针有底层的风险。例如,如果Fred对象需要移动怎么办?当Fred对象可以被安全删除时我们如何获知?如果Fred对象需要(临时的)连续的从磁盘获得怎么办?等等。这些时候的大多数,我们增加一个间接层来管理位置。例如,句柄可以是Fred**,指向Fred*的指针可以保证不会被移动。当Fred对象需要移动时,你只要更新指向Fred*的指针就可以了。或者让用一个整数作为句柄,然后在表或数组或其他地方查询Fred的对象(或者指向Fred对象的指针)。
    重点是当我们不知道要做的事情的细节时,使用句柄。 使用句柄的另一个时机是想要将已经完成的东西含糊化的时候(有时用术语magic cookie也一样,就像这样,“软件传递一个magic cookie来唯一标识并定位适当的Fred对象”)。将已经完成的东西含糊化的原因是使得句柄的特殊细节或表示物改变时所产生的连锁反应最小化。举例来说,当将一个句柄从用来在表中查询的字符串变为在数组中查询的整数时,我们可不想更新大量的代码。当句柄的细节或表示物改变时,维护工作更为简单(或者说阅读和书写代码更容易),因此常常将句柄封装到类中。这样的类常重载operator-> 和 operator*算符(既然句柄的效果象指针,那么它可能看起来也象指针)。 
    (转载)
    引用经常用于“按引用传递(pass-by-reference)”: 
     void swap(int& i, int& j)
     {
       int tmp = i;
       i = j;
       j = tmp;
     }
     
     int main()
     {
       int x, y;
       // ...
       swap(x,y);
     } 
    此处的 i 和 j 分别是main中的 x 和 y。换句话说,i 就是 x —— 并非指向 x 的指针,也不是 x 的拷贝,而是 x 本身。对 i 的任何改变同样会影响 x,反之亦然。这就是作为一个程序员所认知的引用。现在,给你一个不同的角度,这可能会让你更糊涂,那就是引用是如何实现的。典型的情况下,对象 x 的引用 i 是 x 的机器地址。但是,当程序员写 i++ 时,编译器产生增加 x 的代码。更详细的来说,编译器用来寻找 x 的地址位并没有被改变。C 程序员将此认为好像是 C 风格的按指针传递,只是句法不同 (1) 将 & 从调用者移到了被调用者处,(2)消除了*s。换句话说,C 程序员会将 i 看作为宏 (*p),而 p 就是指向 x 的指针(例如,编译器自动地将潜在的指针解除引用;i++被改变为 (*p)++;i = 7 被自动地转变成 *p = 7)。 
      

  3.   

    sizhi(街机时代) 和(dominolili(domino) 说的都不错啊。应该给他们分啊。否则你不够意思啊。
      

  4.   

    句柄其实也类似于指针,不过不是指向对象本身,而是指向包含有有关对象信息的一个内存块,比如进程和线程的句柄,并不指向代码本身,而是指向有关带信息的一个内存块。
    引用,其实也是指针,按thinking in C++的说法,是一种自动dereference的指针,你可以用与使用对象相同的方法来使用它,但在思想中还是应该把它想象为指针。
    指针就是对象的实际地址(当然是逻辑地址)。