GET與SET用法指南

2022-05-31 21:15:12 字數 1752 閱讀 1496

get是讀取屬性時進行的操作,set是設定屬性時進行的操作。定義乙個屬性如果只有get,這個屬性就是唯讀的。同樣,只有set,屬性就是只寫的,當然只寫的屬性是沒有任務意義的。假設類是乙個銀行,既能存錢也能取錢.

1private

m_money;

2private

class

bank()  35

set          6}

m_money   就像銀行裡的自動訪問款機,你看不見裡面的money,但你能用set(存錢),用get(取錢)。m_money是乙個私有字段,是封裝在類中的,類以外的程式不能直接訪問的,類的set和get成員是外部程式訪問類內部屬性的唯一方法,就像你去銀行取錢,你不能直接從銀行的保險櫃裡拿到錢,而是銀行營業人員把錢取出來給你的.

屬性在呼叫者看來就像乙個普通的變數,普通變數怎麼用,它就怎麼用,但作為類的設計者,你可以利用屬性來隱藏你類中的一些字段,使外界只能通過屬性來訪問你的字段,你可以通過屬性來限制外界對你的字段的訪問,就利用get,set,如果你想讓使用者隨意訪問你的字段,那麼就實現set和get,如果只 想讓使用者讀取字段,就只實現get,若只想讓使用者寫字段就只實現set,同時你還可以在set和get中對使用者傳遞來的值進行一些驗證工作,以確保你的字 段將含有正確的值。

1比如   

private

inta;

2public

intindex35

set6

}可以看出,

get\

set有一種函式的特徵。

一則是隱藏元件或類內部的真實成員,

二是用來建立約束的,比如,實現「有我沒你」這種約束。

三是用來響應屬性變化事件,當屬性變化時做某事,只要寫在

set方法裡就行了。

有兩種途徑揭示類的命名屬性——通過域成員或者通過屬性。前者是作為具有公共訪問性的成員變數而被實現的;後者並不直接回應儲存位置,只是通過訪問標誌(accessors)被訪問。

當你想讀出或寫入屬性的值時,訪問標誌限定了被實現的語句。用於讀出屬性的值的訪問標誌記為關鍵字get,而要修改屬性的值的讀寫符標誌記為set。1

:   

using

system;

2:  

3:   

public

class

house

4:   

10:   

set11

:  }

12:   }

13:  

14:   

class

15:   

22:   }   

house類有乙個命名為squarefeet的屬性,它可以被讀和寫。實際的值儲存在乙個可以從類內部訪問的變數中——如果你想當作乙個域成員重寫它,你所要做的就是忽略訪問標誌而把變數重新定義為:

public

intsquarefeet;

對於乙個如此簡單的變數,這樣不錯。但是,如果你想要隱藏類內部儲存結構的細節時,就應該採用訪問標誌。在這種情況下,

set訪問標誌給值引數中的屬性傳遞新值。(可以改名,見第10行。)

除了能夠隱藏實現細節外,你還可自由地限定各種操作:

get和set:允許對屬性進行讀寫訪問。

getonly:只允許讀屬性的值。

setonly:只允許寫屬性的值。

除此之外,你可以獲得實現在set標誌中有效**的機會。例如,由於種種原因(或根本沒有原因),你就能夠拒絕乙個新值。最好是沒有人告訴你它是乙個動態屬性——當你第一次請求它後,它會儲存下來,故要盡可能地推遲資源分配。

GET與SET用法指南

get是讀取屬性時進行的操作,set是設定屬性時進行的操作。定義乙個屬性如果只有get,這個屬性就是唯讀的。同樣,只有set,屬性就是只寫的,當然只寫的屬性是沒有任務意義的。假設類是乙個銀行,既能存錢也能取錢.private m money private class bank set m mone...

SQLAlchemy用法指南

資料庫操作都存在4個基本的功能,增 讀 改 刪 crud 增 db.session.add 讀 使用model.query model.query是db.session.query model 的簡寫 model.query.all 資料庫中所有行 model.query.limit 10 all ...

nc 用法指南

原文 man nc translate by google nc 1 bsd通用命令手冊nc 1 名稱 nc 任意tcp和udp連線並偵聽 概要nc 46bcddhklnrstuuvzz i長度 i間隔 o長度 p 使用者名稱 p源埠 q秒 s原始碼 t關鍵字 v rtable w超時 x prox...