OC基础-SEL解析14

2023-10-30 06:10
文章标签 基础 解析 14 oc sel

本文主要是介绍OC基础-SEL解析14,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


1.什么是SEL


    SEL 全称叫做  selector 选择器.

    SEL 1个数据类型. 所以要在内存中申请空间存储数据.

    SEL其实是1个类. SEL对象是用来存储1个方法的.



2. 类的存储方式


    类是以Class对象的形式存储在代码段之中.


    类名:存储的这个类的类名. NSString


    还要将方法存储在类对象之中.如何将方法存储在类对象之中.


    1). 先创建1SEL对象.

    2). 将方法的信息存储在这个SEL对象之中.

    3). 再将这个SEL对象作为类对象的属性.



3. 拿到存储方法的SEL对象.


    1). 因为SEL1typedef类型的 在自定义的时候已经加*.

    所以 我们在声明SEL指针的时候 不需要加*


    2). 取到存储方法的SEL对象,

    SEL s1 = @selector(方法名);



4. 调用方法的本质.


    [stu1 sayHi];

    内部的原理:

    1). 先拿到存储sayHi方法的SEL对象,也就是拿到存储sayHi方法的SEL数据. SEL消息.


    2). 将这个SEL消息发送给stu1对象.


    3). 这个时候,stu1对象接收到这个SEL消息以后 就知道要调用方法


    4). 根据对象的isa指针找到存储类的类对象.


    5). 找到这个类对象以后 在这个类对象中去搜寻是否有和传入的SEL数据相匹配的.

    如果有 就执行  如果没有再找父类 直到NSObject



    OC最重要的1个机制:消息机制.

    调用方法的本质其实就是为对象发送SEL消息.

    [stu1 sayHi]; stu1对象发送1sayHi消息.


5. 重点掌握:


    1).方法是以SEL对象的形式存储起来.

    2).如何拿到存储方法的SEL对象.




6. 手动的为对象发送SEL消息.


    1). 先得到方法的SEL数据.


    2). 将这个SEL消息发送给p1对象.


    调用对象的方法 SEL数据发送给对象.

    - (id)performSelector:(SEL)aSelector;


    Student *stu1 = [Student new];

    SEL s1 = @selector(sayHi);

    [stu1 performSelector:s1]; [p1 sayHi]效果是完全一样的.



   3). 调用1个对象的方法有两种.

      1). [对象名 方法名];


      2). 手动的为对象发送SEL消息.



7. 注意事项:



    1). 如果方法有参数 那么方法名是带了冒号的.


    2). 如果方法有参数,如何传递参数.

    那么就调用另外1个方法.


    - (id)performSelector:(SEL)aSelector withObject:(id)object;

    - (id)performSelector:(SEL)aSelector withObject:(id)object1 withObject:(id)object2;



    3). 如果有多个参数


    把参数封装到对象里

这篇关于OC基础-SEL解析14的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/306095

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

OWASP十大安全漏洞解析

OWASP(开放式Web应用程序安全项目)发布的“十大安全漏洞”列表是Web应用程序安全领域的权威指南,它总结了Web应用程序中最常见、最危险的安全隐患。以下是对OWASP十大安全漏洞的详细解析: 1. 注入漏洞(Injection) 描述:攻击者通过在应用程序的输入数据中插入恶意代码,从而控制应用程序的行为。常见的注入类型包括SQL注入、OS命令注入、LDAP注入等。 影响:可能导致数据泄

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [