IOS遍历未知对象属性、函数

#import <objc/runtime.h>


@implementation NSObject (PropertyListing)   


/* 获取对象的所有属性 */

- (NSDictionary *)properties_aps

{

    NSMutableDictionary *props = [NSMutableDictionary dictionary];   

   unsigned int outCount, i;   

   objc_property_t *properties = class_copyPropertyList([self class], &outCount);   

   for (i = 0; i<outCount; i++)

    {

       objc_property_t property = properties[i];

       const char* char_f =property_getName(property);

       NSString *propertyName = [NSString stringWithUTF8String:char_f];

       id propertyValue = [self valueForKey:(NSString *)propertyName];   

       if (propertyValue) [props setObject:propertyValue forKey:propertyName];   

    }   

   free(properties);   

   return props;   

}   


/* 获取对象的所有方法 */

-(void)printMothList

{

   unsigned int mothCout_f =0;

   Method* mothList_f = class_copyMethodList([self class],&mothCout_f);

   for(int i=0;i<mothCout_f;i++)

    {

       Method temp_f = mothList_f[i];

       IMP imp_f = method_getImplementation(temp_f);

       SEL name_f = method_getName(temp_f);

       const char* name_s =sel_getName(method_getName(temp_f));

       int arguments = method_getNumberOfArguments(temp_f);

       const char* encoding =method_getTypeEncoding(temp_f);

       NSLog(@"方法名:%@,参数个数:%d,编码方式:%@",[NSString stringWithUTF8String:name_s],

                                            arguments,

                            [NSString stringWithUTF8String:encoding]);

    }

   free(mothList_f);

}



@end 



  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
二叉树是一种常见的数据结构,在iOS开发中,我们经常会涉及到对二叉树进行遍历。常见的遍历方式包括前序遍历、中序遍历和后序遍历。 前序遍历是指首先访问根节点,然后按照先左后右的顺序递归遍历左右子树。在iOS中,可以使用递归或者栈来实现前序遍历,具体实现如下: ``` - (void)preOrderTraversal:(Node *)rootNode { if (rootNode) { NSLog(@"%d", rootNode.value); // 访问根节点 [self preOrderTraversal:rootNode.leftNode]; // 遍历左子树 [self preOrderTraversal:rootNode.rightNode]; // 遍历右子树 } } ``` 中序遍历是指首先遍历左子树,然后访问根节点,最后遍历右子树。同样,可以使用递归或者栈来实现中序遍历,具体实现如下: ``` - (void)inOrderTraversal:(Node *)rootNode { if (rootNode) { [self inOrderTraversal:rootNode.leftNode]; // 遍历左子树 NSLog(@"%d", rootNode.value); // 访问根节点 [self inOrderTraversal:rootNode.rightNode]; // 遍历右子树 } } ``` 后序遍历是指首先遍历左子树,然后遍历右子树,最后访问根节点。同样,可以使用递归或者栈来实现后序遍历,具体实现如下: ``` - (void)postOrderTraversal:(Node *)rootNode { if (rootNode) { [self postOrderTraversal:rootNode.leftNode]; // 遍历左子树 [self postOrderTraversal:rootNode.rightNode]; // 遍历右子树 NSLog(@"%d", rootNode.value); // 访问根节点 } } ``` 以上是iOS中实现二叉树前中后序遍历的一种方式,具体的实现方式可以根据实际需求进行灵活调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值