常用面試題目:關聯、聚合以及組合的區別
- 筆試題目
- 關注:8.18K次
涉及到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(%dn,*fp);
}
void findcredit(int ** fpp)
{
while(**fpp!=0)
if(**fpp<0) break;
else (*fpp)++;
}
首先用一個數組的地址初始化指針fp,然後把該指針的地址作為實參傳遞給函數findcredit()。findcredit()函數通過表達式**fpp間接地得到數組中的數據。為遍歷數組以找到一個負值,findcredit()函數進行自增運算的對象是調用者的指向數組的指針,而不是它自己的指向調用者指針的指針。語句(*fpp)++就是對形參指針指向的指針進行自增運算的。但是因為*運算符高於++運算符,所以圓括號在這裏是必須的,如果沒有圓括號,那麼++運算符將作用於二重指針fpp上。
- 文章版權屬於文章作者所有,轉載請註明 https://wjfww.com/qiuzhi/bishi/wy6m8w.html