常用面试题目:关联、聚合以及组合的区别
admin
2024-01-27 10:03:48
0

常用面试题目:关联、聚合以及组合的区别

  涉及到UML中的一些概念:关联是表示两个类的一般性联系,比如“学生”和“老师”就是一种关联关系;聚合表示has-a的关系,是一种相对松散的关系,聚合类不需要对被聚合类负责,用空的菱形表示聚合关系

  从实现的角度讲,聚合可以表示为:

  class A {…} class B { A* a; …..}

  而组合表示contains-a的关系,关联性强于聚合:组合类与被组合类有相同的生命周期,组合类要对被组合类负责,采用实心的菱形表示组合关系

  实现的形式是:

  class A{…} class B{ A a; …}
拓展:

  指针的指针

  指针的指针看上去有些令人费解,

常用面试题目:关联、聚合以及组合的区别

。它们的声明有两个星号。例如:

  char ** cp;

  如果有三个星号,那就是指针的指针的指针,四个星号就是指针的指针的指针的指针,依次类推。当你熟悉了简单的例子以后,就可以应付复杂的情况了。当然,实际程序中,一般也只用到 二级指针,三个星号不常见,更别说四个星号了。

  指针的指针需要用到指针的地址。

  char c='A';

  char *p=&c;

  char **cp=&p;

  通过指针的指针,不仅可以访问它指向的指针,还可以访问它指向的指针所指向的数据,

资料共享平台

《常用面试题目:关联、聚合以及组合的区别》()。下面就是几个这样的例子:

  char *p1=*cp;

  char c1=**cp;

  你可能想知道这样的结构有什么用。利用指针的指针可以允许被调用函数修改局部指针变量和处理指针数组。

  void FindCredit(int **);

  main()

  {

  int vals[]={7,6,5,-4,3,2,1,0};

  int *fp=vals;

  FindCredit(&fp);

  printf(%d\n,*fp);

  }

  void FindCredit(int ** fpp)

  {

  while(**fpp!=0)

  if(**fpp<0) break;

  else (*fpp)++;

  }

  首先用一个数组的'地址初始化指针fp,然后把该指针的地址作为实参传递给函数FindCredit()。FindCredit()函数通过表达式**fpp间接地得到数组中的数据。为遍历数组以找到一个负值,FindCredit()函数进行自增运算的对象是调用者的指向数组的指针,而不是它自己的指向调用者指针的指针。语句(*fpp)++就是对形参指针指向的指针进行自增运算的。但是因为*运算符高于++运算符,所以圆括号在这里是必须的,如果没有圆括号,那么++运算符将作用于二重指针fpp上。

相关内容

热门资讯

高中班主任教学工作计划 高中班主任教学工作计划高中班主任教学工作计划1  高三一年,可以说是一个人学习生活中最重要的一年,在...
西安作文 西安作文西安西安是陕西的省会,是一座历史悠久的城市。城墙在西安的'中央,灰墙`灰瓦,又庄严又古老,城...
时不欺吾,以时为标高中优秀议... 时不欺吾,以时为标高中优秀议论文  在学习和工作中,许多人都有过写论文的经历,对论文都不陌生吧,论文...
信息和信息的作用高中优秀作文 信息和信息的作用高中优秀作文  人类生活在信息的海洋中。人们每时每刻在自觉或不自觉地与信息打交道。那...
我心中的星初中作文600字 我心中的星初中作文600字  纵观千古,英雄无数,恰似一片碑林之中屹立着无边无际铭刻着功勋的丰碑,但...