Description

簡述description

description方法是NSObject類的一個實例方法,因此所有的Object-C對象都有description方法桅狠。description方法返回的永遠是字符串讼载。

NSLog(@"%@", self);

重寫runTime的方法來截取調(diào)用上述代碼時到底走了哪個方法

+ (BOOL)resolveInstanceMethod:(SEL)sel{
    return YES;
}
//截取的方法:發(fā)現(xiàn)截取的方法是descriptionWithLocale而不是description,個人猜測是在運行時給轉(zhuǎn)成了descriptionWithLocale:中跌,而我們能夠拿到的只有description方法咨堤。
sel = "descriptionWithLocale:"
//打印結(jié)果
<ViewController: 0x7fbae8c07830>

而我們在實際使用中對于對象的內(nèi)存地址并不感冒,如果一個對象有多個屬性并且我們想打印這些屬性漩符,例如self具有name一喘、sex、birth等屬性嗜暴,我們需要這么做:

NSLog(@"obj == %@ name == %@ sex == %@ birth == %@", self, self.name, self.sex, self.birth);

我們也可以通過重寫description方法來實現(xiàn),這樣的話只要我們對這個對象進行打印就會打印出這個對象的類以及屬性

- (NSString *)description{
    return [NSString stringWithFormat:@"obj == %@ name == %@ sex == %@ birth == %@", self, self.name, self.sex, self.birth];
}

description陷阱:

1.千萬不要在description方法中同時使用%@和self,下面的寫法是錯誤的

- (NSString *)description {
return [NSString stringWithFormat:@"%@", self];
}

2.同時使用了%@和self,代表要調(diào)用self的description方法,因此最終會導(dǎo)致程序陷入死循環(huán),循 環(huán)調(diào)用description方法


PS:過多的打印日志津滞,你又不想刪除,也不想造成安全問題灼伤,建議添加一個DEBUG模式:

#ifdef DEBUG
#define LYLog(...) NSLog(__VA_ARGS__)
#else
#define LYLog(...)
#endif
//平常的時候使用LYLog而不再使用NSLog

等上線的時候關(guān)閉了DEBUG模式就不會有打印了触徐。。狐赡。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末撞鹉,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌鸟雏,老刑警劉巖享郊,帶你破解...
    沈念sama閱讀 211,743評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異孝鹊,居然都是意外死亡炊琉,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,296評論 3 385
  • 文/潘曉璐 我一進店門又活,熙熙樓的掌柜王于貴愁眉苦臉地迎上來苔咪,“玉大人,你說我怎么就攤上這事柳骄⊥派停” “怎么了?”我有些...
    開封第一講書人閱讀 157,285評論 0 348
  • 文/不壞的土叔 我叫張陵耐薯,是天一觀的道長舔清。 經(jīng)常有香客問我,道長曲初,這世上最難降的妖魔是什么体谒? 我笑而不...
    開封第一講書人閱讀 56,485評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮臼婆,結(jié)果婚禮上抒痒,老公的妹妹穿的比我還像新娘。我一直安慰自己目锭,他們只是感情好评汰,可當(dāng)我...
    茶點故事閱讀 65,581評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著痢虹,像睡著了一般被去。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上奖唯,一...
    開封第一講書人閱讀 49,821評論 1 290
  • 那天惨缆,我揣著相機與錄音,去河邊找鬼丰捷。 笑死坯墨,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的病往。 我是一名探鬼主播捣染,決...
    沈念sama閱讀 38,960評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼停巷!你這毒婦竟也來了耍攘?” 一聲冷哼從身側(cè)響起榕栏,我...
    開封第一講書人閱讀 37,719評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蕾各,沒想到半個月后扒磁,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,186評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡式曲,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,516評論 2 327
  • 正文 我和宋清朗相戀三年妨托,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吝羞。...
    茶點故事閱讀 38,650評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡兰伤,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出脆贵,到底是詐尸還是另有隱情医清,我是刑警寧澤起暮,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布卖氨,位于F島的核電站,受9級特大地震影響负懦,放射性物質(zhì)發(fā)生泄漏筒捺。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,936評論 3 313
  • 文/蒙蒙 一纸厉、第九天 我趴在偏房一處隱蔽的房頂上張望系吭。 院中可真熱鬧,春花似錦颗品、人聲如沸肯尺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,757評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽则吟。三九已至,卻和暖如春锄蹂,著一層夾襖步出監(jiān)牢的瞬間氓仲,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,991評論 1 266
  • 我被黑心中介騙來泰國打工得糜, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留敬扛,地道東北人。 一個月前我還...
    沈念sama閱讀 46,370評論 2 360
  • 正文 我出身青樓朝抖,卻偏偏與公主長得像啥箭,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子治宣,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,527評論 2 349

推薦閱讀更多精彩內(nèi)容

  • 轉(zhuǎn)至元數(shù)據(jù)結(jié)尾創(chuàng)建: 董瀟偉急侥,最新修改于: 十二月 23, 2016 轉(zhuǎn)至元數(shù)據(jù)起始第一章:isa和Class一....
    40c0490e5268閱讀 1,690評論 0 9
  • 123.繼承 一個類可以從另外一個類繼承方法,屬性和其他特征抬驴。當(dāng)一個類繼承另外一個類時, 繼承類叫子類, 被繼承的...
    無灃閱讀 1,383評論 2 4
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,782評論 25 707
  • What is love?We can't explain this concept accurately.But...
    HaleyinSydney閱讀 298評論 0 0
  • 2017年12月9日布持,我會不由自主地往前看,10月份以及更靠前的一些日子陕悬。 固定的上班時間题暖,固定的生活規(guī)律,腦子里...
    lexus杜曉磊閱讀 430評論 0 1