iOS模型打印

#import <objc/runtime.h>

- (NSString *)description
{
    NSMutableDictionary *dictionary = [NSMutableDictionary dictionary];
    uint count;
    objc_property_t *properties = class_copyPropertyList([self class], &count);
    for (int i = 0; i < count; i++)
    {
        objc_property_t property = properties[i];
        NSString *name = @(property_getName(property));
        id value = [self valueForKey:name]?:@"nil";
        [dictionary setObject:value forKey:name];
    }
    
    free(properties);
    return [NSString stringWithFormat:@"<%@:%p> -- %@", [self class], self, dictionary];
    
}

很多時(shí)候,我們?cè)跀帱c(diǎn)調(diào)試的時(shí)候庸疾,并不是使用NSLog(@"%@",model);來(lái)打印模型,而是通過(guò)po這個(gè)命令,我們需要重寫debugDescription方法而不是description方法

debugDescription方法只會(huì)在調(diào)試po的時(shí)候調(diào)用,而在代碼中打印不會(huì)調(diào)用业踢。但是我們需要在每個(gè)模型中都重寫這個(gè)方法,而且代碼都不一樣礁扮,肯定受不了知举。我的解決方式是寫一個(gè)NSObject的分類NSObject+DebugDescription并重寫debugDescription,并處理了po其他類型的情況

#import "NSObject+DebugDescription.h"
#import <objc/runtime.h>

@implementation NSObject (DebugDescription)

- (NSString *)debugDescription
{
    if ([self isKindOfClass:[NSArray class]] || [self isKindOfClass:[NSDictionary class]] || [self isKindOfClass:[NSNumber class]] || [self isKindOfClass:[NSString class]])
    {
        return self.debugDescription;
    }
    NSMutableDictionary *dictionary = [NSMutableDictionary dictionary];
    uint count;
    objc_property_t *properties = class_copyPropertyList([self class], &count);
    for (int i = 0; i < count; i++)
    {
        objc_property_t property = properties[i];
        NSString *name = @(property_getName(property));
        id value = [self valueForKey:name]?:@"nil"; // 默認(rèn)值為nil字符串
        [dictionary setObject:value forKey:name];
    }
    free(properties);
    return [NSString stringWithFormat:@"<%@: %p> -- %@", [self class], self, dictionary];
}

@end
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末太伊,一起剝皮案震驚了整個(gè)濱河市雇锡,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌僚焦,老刑警劉巖锰提,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡立肘,警方通過(guò)查閱死者的電腦和手機(jī)边坤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)谅年,“玉大人茧痒,你說(shuō)我怎么就攤上這事√吖剩” “怎么了文黎?”我有些...
    開封第一講書人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)殿较。 經(jīng)常有香客問(wèn)我耸峭,道長(zhǎng),這世上最難降的妖魔是什么淋纲? 我笑而不...
    開封第一講書人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任劳闹,我火速辦了婚禮,結(jié)果婚禮上洽瞬,老公的妹妹穿的比我還像新娘本涕。我一直安慰自己,他們只是感情好伙窃,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開白布菩颖。 她就那樣靜靜地躺著,像睡著了一般为障。 火紅的嫁衣襯著肌膚如雪晦闰。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,816評(píng)論 1 290
  • 那天鳍怨,我揣著相機(jī)與錄音呻右,去河邊找鬼。 笑死鞋喇,一個(gè)胖子當(dāng)著我的面吹牛声滥,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播侦香,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼落塑,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了鄙皇?” 一聲冷哼從身側(cè)響起芜赌,我...
    開封第一講書人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎伴逸,沒想到半個(gè)月后缠沈,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體酪呻,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡饲趋,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年呜笑,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了横侦。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡柬赐,死狀恐怖亡问,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情肛宋,我是刑警寧澤州藕,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站酝陈,受9級(jí)特大地震影響床玻,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜沉帮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一锈死、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧穆壕,春花似錦待牵、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至川背,卻和暖如春压彭,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背渗常。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留汗盘,地道東北人皱碘。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像隐孽,于是被迫代替她去往敵國(guó)和親癌椿。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

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