反射类属性方法

广告数据实体:
// AdModel.h
@interface AdModel: NSObject
{
}

@property (nonatomic, assign) int       row;
@property (nonatomic, retain) NSString *picture;

@end
// AdModel.m
@implementation AdModel

@synthesize row      = _row;
@synthesize picture  = _picture;

- (void)dealloc
{
    [_picture release];
    [super dealloc];
}

@end


用SQLiteHelper将数据库内容返回NSDictionary

然后通过反射类属性将数据保存到实体集合



// NSObject+Add

- (NSArray *)getPropertyListByClass: (Class)clazz
{
    u_int count; 
    
    objc_property_t *properties  = class_copyPropertyList(clazz, &count);
    
    NSMutableArray *propertyArray = [NSMutableArray arrayWithCapacity:count];
    
    for (int i = 0; i < count ; i++) 
    { 
        const char* propertyName = property_getName(properties[i]);
        [propertyArray addObject: [NSString  stringWithUTF8String: propertyName]];
    } 
    
    free(properties);
    
    return propertyArray;
}


#define AD_INFO_QUERY  \
@"SELECT * FROM ad ORDER BY row"

- (NSArray *)queryAdInfo
{    
    NSMutableArray *adEntityArray   = nil;
    NSUInteger     count            = [[_sqliteHelper countRowsAtTable: @"ad"] intValue];

    NSString     *conn   = [NSString stringWithFormat: AD_INFO_QUERY];
    SQLiteHelper *obj    = [_sqliteHelper getQuery: conn];

    if (obj != nil)
    {
        adEntityArray         = [NSMutableArray arrayWithCapacity: count];
        NSArray *propertyList = [self getPropertyListByClass: [EntityAdInfo class]];

        for (NSMutableDictionary *dic in obj)
        {
            EntityAdInfo *adEntity = [[EntityAdInfo alloc] init];
            
            for (NSString *key in propertyList)
            {
                 [adEntity setValue: [dic objectForKey: key] forKey: key];
            }

            [adEntityArray addObject: adEntity];
            [adEntity release];
        }
    }
    return adEntityArray;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值