首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

KVO 在 iOS开发中的应用

当然我想起在UNITY3D中,如果检视面板的数值发生改变对应的GameObject发生位移之类的。我曾经实现了一个inspector的编辑器类,值改变直接通知(其实是调用)对应的函数。...在iOS这里 一切发生的那么自然。不需要额外实现 这是iOS的特性之一 名曰:KVO 。 前情提要 上一篇 KVC 讲到需要遵循的几条几本规则在 KVO 中同样适用。...在值改变之前和值改变之后。 0 不带任何参数进去 传递给监听的值在接受函数ofObject:(id)object可以获取到。...有时候我们在某些条件下不希望接受到KVO的通知,需要重写如下方法: NSInteger HP = 10; +(BOOL)automaticallyNotifiesObserversOfStringOnFoo...手动触发KVO也是允许的,下面主要使用到了 willChangeValueForKey / didChangeValueForKey 这两个函数。即使禁止了自动通知也可以直接在get函数中触发。

7910

在 iOS 工程中 Cocoapods 的使用

我们在开发 iOS 程序的时候,往往都会根据需要导入很多的第三方框架,但是不同的框架完成的功能不同,所以导入的方式也不同,并不是把它直接拖进工程中就完事了,我们需要配置各种环境,链接各种库文件等等。...这个时候我们就需要用到 cocoapods 来管理我们的第三方了,在我们有了 CocoaPods 这个工具之后,只需要将用到的第三方开源库放到一个名为 Podfile 的文件中, 然后在命令行执行 $...网上也有类似的教程,但是有些很旧,有些写的不详细,导致新手在使用的时候整的一头雾水,我就来说下。...### 第五步: 进入你的工程目录,这里建议直接右键你工程中.xcodeproj 文件选择在终端中打开,然后 在终端中输入命令 cd ..  ...以后打卡工程就直接打开这个文件就好啦 其中 podfile 文件中显示了我们这个工程中所以集成的第三方, 想修改版本的话就把后面的版本号改成你所需要的版本号就好,想删除的话就把这行删掉,想添加的话就用第五部的搜索命令去搜索然后同样把搜索结果中以

1.1K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    category在iOS开发中的使用

    上面是后端同学按照照module的方式开发的服务,在整个的项目中请求中前缀相同而每个module都有自己的前缀,结合起来整个请求URL格式就可以拆分为 HOT:PORT?...正如我们的标题一样我们采用category将统一的网络请求拆分到不同的文件中---类似服务端的module一样将器拆分到不同的文件中进行管理 比如上面的我们将通过用的网络请求放置到ApiFetch这个类中...保持一致我们进行各模块的网络请求管理以便根据某一某块的特殊要求作出变化,例如,user模块中 -(void)userGetFetch:(NSString *)url query:(NSDictionary...中附带一个module对应的参数---user,对应的Oder也会添加一个order作为模块url参数的前缀 然后是模块对应的url的管理啦: 如上图每个模块都有自己的path对应url,我们可以统一的防止在...category对应的头文件中 总之一句话就是分而治之,将杂而乱的url分化到不同的模块中去,按照每个模块的特性去进行管理 最后我们看看怎么使用吧 user模块的网络请求实例 NSDictionary

    76410

    RunLoop在iOS开发中的应用

    概要 RunLoop在iOS开发中的应用范围并没有像runtime 那样广泛,我们通过CFRuntime的源代码可知runloop跟线程的是密不可分的,一个线程一定会创建一个对应的runloop,只是主线程创建就自动...此外,runloop并不是一个简单的do-while,作为OSX/iOS系统中Event Loop表现,runloop需要处理消息事件,在没有消息的时候休眠,有消息事件的时候立刻唤醒。   ...所有的关于这个的都会拿AF2.X的代码说明这个常驻的案例,如果同学开发iOS稍微有点年长的话或者古董代码的都会用到网络第三方库ASIHTTPRequest,也用到利用CFRunLoopAddSource...系统会监听主线程中runloop的的进入/休眠、退出的activities 来处理autoreleasepool,也是同学们长讨论的自动释放池在什么时候释放的问题。...image.png 3.3 TableView中实现平滑滚动延迟加载图片 顺带提一下,这个我在开发中没有用到。

    1.9K20

    【DB笔试面试576】在Oracle中,简述Oracle中的游标。

    ♣ 题目部分 在Oracle中,简述Oracle中的游标。 ♣ 答案部分 在介绍游标之前先介绍一下Oracle数据库中库缓存(Library Cache)的作用及其组成结构。...当同样的SQL语句和PL/SQL语句再次被执行的时候就可以直接利用已经缓存在库缓存中的那些相关对象而无须再次从头开始解析,这样就提高了这些SQL语句和PL/SQL语句在重复执行时的执行效率。...库缓存(Library Cache)在SGA中的位置如下图所示: ?...可以使用视图V$DB_OBJECT_CACHE(基表为X$KGLOB)来查询当前缓存在库缓存中的所有对象。...当Oracle要执行目标SQL“select * from lhr.emp”时,首先会对该SQL的SQL文本进行哈希运算,然后根据得到的哈希值找到相关的Hash Bucket,在Hash Bucket中遍历对应的库缓存对象句柄链表

    1.3K20

    iOS小技能:链式编程在iOS开发中的应用

    1.2 面向对象 万物皆对象 面向对象对比面向过程的优胜之处在于,名词化的概念比动词化的描述,更便于人类理解。 这也是相比函数式编程的主要优点,许多函数是难以命名的,但对象却很容易。...封装是为了更好的重用性、可扩展性,但要综合考虑性能问题,即使新增了判断也会增加性能的消耗,只是不会量级的增加。比如简单工厂和抽象工厂(反射机制)的封装,会增加性能的消耗。...的妙用:结合block和方法的优点实现iOS的链式编程) 文章:https://blog.csdn.net/z929118967/article/details/107835195 从CSDN资源下载完整..., 76)); }]; } return _imgForReason; } see also iOS...CSDN博主「#公众号:iOS逆向」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

    90430

    Runtime在iOS开发中的实际应用

    ,介绍目前在项目中runtime的具体使用,真切希望和各位同学探讨。...1 关联对象(AssociatedObject ) Catagory主要为已经存在的类(主要是系统类)扩展新的方法,关联对象是runtime在开发中应用的最广泛,其主要用于为Catagory的对象增加属性...能保证在类的初始化过程中被加载。...处理用户登录 5.4Crash的防范 OC中容器类在空值nil 和数组越界都会直接导致我们app 的crash 我们一种处理方式是利用Category增加新方法中判断值是否为空或者越界,对于新工程我们使用大家约定使用容器的...6 逆向开发 逆向开发主要集中在iOS越狱方面,逆向开发可以让我们在iOS开发中打开另一扇门,对于大部门开发者来说很少接触这个领域,我也是在工作中才接触到iOS的越狱,逆向开发的基础就是利用Method

    1K20

    多线程在iOS开发中的应用

    NSOperationQueue的常见方法、最大并发数、操作依赖、队列的取消\暂停\恢复 一、概念 1、进程:系统中正在运行的一个应用程序 2、线程:1个进程想要执行任务,必须得有线程。...即线程是进程的基本执行单元 1)线程的串行:一个线程中任务的执行是串行的 2)多线程的原理:同一时间,CPU只能处理一条线程。...多线程并发执行,其实就是CPU快速地在多条线程之间调度(如果CPU调度的时间足够快,就造成了多线程并发执行的假象) 二、多线程在iOS开发中的应用 1、什么是主线程:一个iOS程序运行之后,默认会开启一条线程...,称为“主线程”,或者“UI线程” 2、主线程的主要作用: 显示、刷新UI界面 处理UI事件(点击、滚动、拖拽) 2.1 主线程的使用注意事项: 别将比较耗时的操作放到主线程中 一般的解决方案就是将那些耗时的操作放到另外一个线程中去执行...2.2 iOS中多线程的实现方案 公众号:iOS逆向 iOS支持多个层次的多线程编程,层次越高的抽象程度越高,使用也越方便,也是苹果最推荐使用的方法。

    1.4K30

    哈希表及在iOS中的应用

    记录的存储位置=f(关键字) 这里的对应关系f称为哈希函数(散列函数),采用散列技术将记录存储在一块连续的存储空间中,这块连续存储空间称为散列表或哈希表(Hash table)。...解决冲突的常用方法: 1.开放定址法:使用某种探查(亦称探测)技术在散列表中寻找下一个空的散列地址,只要散列表足够大,空的散列地址总能找到。...,向后查找即可 image.png 哈希在OC中的应用 NSDictionary 1.使用 hash表来实现key和value之间的映射和存储 2.字典的key需要遵循NSCopying协议,重写hash...3.NSString类作为key的时候不需要重写,系统已经重写过了,对于值相同的字符串得到的哈希值相同 NSDictionary实现原理 iOS底层原理:NSDictionary原理 runloop kvo...APP签名,MD5加密 作者:Olivia_S 链接:https://www.jianshu.com/p/48709f466db9 来源:简书 著作权归作者所有。

    2.1K21

    【DB笔试面试520】在Oracle中,Oracle的DBLINK是什么?

    ♣ 题目部分 在Oracle中,Oracle的DBLINK是什么?...♣ 答案部分 当用户要跨本地数据库访问另外一个数据库表中的数据时,本地数据库中必须创建了远程数据库的DBLINK,通过DBLINK可以像访问本地数据库一样访问远程数据库表中的数据。...DBLINK的分类如下表所示: 类型 用户 描述 Private 创建database link的user拥有该database link 在本地数据库的特定的schema下建立的database link.../密码,然后在本地数据库中通过DBLINK访问远程数据库“TNS_BJLHR”中SCOTT.TB_TEST表,SQL语句如下所示: SELECT * FROM SCOTT.TB_TEST@DBL_BJLHR...; 创建DBLINK的第二种方式,是在本地数据库tnsnames.ora文件中没有配置要访问的远程数据库的时候,而直接将相关的内容写到DBLINK的配置中,如下所示: CREATE DATABASE LINK

    1.8K20

    【DB笔试面试718】在Oracle中,集群的日志包括哪些?

    在Oracle RAC环境中,对集群中的日志进行定期检查是必不可少的。通过查看集群日志,可以早期定位集群环境中出现的问题,以便将问题消灭在萌芽状态。...下面简单介绍一下有关Oracle集群环境中日志的结构,有助于方便快速地查找所需的日志文件。...GRID_HOME/log/$HOSTNAME/evmd/evmd.log gpnpd.log:$GRID_HOME/log/$HOSTNAME/gpnpd/gpnpd.log (3)Nodeapp日志,放的是...Nodeapp的日志,包括ONS和VIP: $GRID_HOME/log/$HOSTNAME/racg/ (4)工具执行日志,包括工具ocrcheck、ocrconfig、ocrdump、oifcfg...,在Oracle 18c中,集群的告警日志已经归于ADR中,目录位置在GRID_BASE/diag/HOSTNAME/crs/trace中,例如: /u01/app/grid/diag/crs/rac18c-n1

    70230

    在苹果应用商店的17个应用程序中发现iOS Clicker Trojan

    这家软件开发公司已经在苹果应用商店中发布了51个应用程序,并且在谷歌应用商店中也拥有28个安卓应用程序。 此次iOS应用程序开发人员使用同一C2服务器,但安卓应用程序却没有表现出任何恶意行为。...然而,AppAspect的安卓应用程序过去曾经被感染并从商店中删除,将在以后重新发布。 目前,研究人员尚不清楚恶意代码是由应用程序的开发人员有意添加还是在加入受感染的第三方框架后无意添加的。...研究人员说:“我们对所有免费iTunes应用程序进行了测试,结果表明,在35个免费应用程序中,有17个都感染了相同的恶意点击程序,并且连接同一个C&C服务器。”...保护个人移动设备和数据 Wandera的研究人员总结,这是应用商店中针对一系列恶意应用程序的最新发现,也证明了恶意软件确实会影响iOS生态系统。...在正常的网络环境中,移动恶意软件仍然是鲜为人知的威胁之一,但在具有针对性的攻击场景中,使用率更高。建议用户检查所安装的应用程序是否合法,并具有良好的评价,并确保正常运行时,可以不要求更多的权限。

    2.6K20

    【DB笔试面试718】在Oracle中,集群的日志包括哪些?

    ♣ 题目部分 在Oracle中,集群的日志包括哪些? ♣ 答案部分 在Oracle RAC环境中,对集群中的日志进行定期检查是必不可少的。...通过查看集群日志,可以早期定位集群环境中出现的问题,以便将问题消灭在萌芽状态。下面简单介绍一下有关Oracle集群环境中日志的结构,有助于方便快速地查找所需的日志文件。...GRID_HOME/log/$HOSTNAME/evmd/evmd.log 4gpnpd.log:$GRID_HOME/log/$HOSTNAME/gpnpd/gpnpd.log (3)Nodeapp日志,放的是...Nodeapp的日志,包括ONS和VIP: 1$GRID_HOME/log/$HOSTNAME/racg/ (4)工具执行日志,包括工具ocrcheck、ocrconfig、ocrdump、oifcfg...,在Oracle 18c中,集群的告警日志已经归于ADR中,目录位置在$GRID_BASE/diag/$HOSTNAME/crs/trace中,例如: 1/u01/app/grid/diag/crs/rac18c-n1

    46800

    CSS中的float定位技术在iOS上的实现

    不过在 CSS 中,任何元素都可以浮动,假如在一行之上只有极少的空间可供浮动元素,那么这个元素会跳至下一行,这个过程会持续到某一行拥有足够的空间为止。...浮动布局主要用于那些图文环绕以及实现一些界面不规则排列的场景,并且浮动定位技术在WEB前端开发中应用的非常普遍。...iOS中实现不规则排列的方式 在iOS中我们可以通过frame以及AutoLayout两种方法来实现界面的布局。...浮动布局的包裹属性 上面分别的介绍了浮动布局的建立,以及子视图的扩展的属性设置来实现视图在浮动布局中的浮动方式、是否清除浮动、以及比重的设置方法。...而且其提供的能力甚至要比CSS中的浮动属性更加强大。而我们在进行WEB前端开发时很多的界面布局其实都是通过CSS的浮动属性来完成的。

    2.2K20

    【DB笔试面试787】在Oracle中,参数DB_BLOCK_CHECKSUM和DB_BLOCK_CHECKING的作用是什么?

    ♣ 题目部分 在Oracle中,参数DB_BLOCK_CHECKSUM和DB_BLOCK_CHECKING的作用是什么? ♣ 答案部分 何时进行数据块的一致性检查呢?...当一个数据块被读或写的时候,将对块的进行一致性检查,检查的内容包括块的版本、比较块在Cache和Block Buffer中的数据块地址,然后根据要求进行校验和(checksum)。...DB_BLOCK_CHECKSUM是一种物理检查,用于防止物理I/O的损坏,默认值是TYPICAL,只有在写入(DBWn常规写或用户进程直接路径写入)数据文件时,根据一个CHECKSUM算法计算数据块的校验和...如果将其设置为FULL,还会验证内存中的块的CHECKSUM值,避免内存的问题导致块的损坏。即使将DB_BLOCK_CHECKSUM值设置为FALSE,对于SYSTEM表空间也会进行相关的验证。...DB_BLOCK_CHECKING参数(默认值为FALSE)主要用于数据块的逻辑一致性检查,但只是在块内,不包括块间的逻辑检查,用于防止在内存中损坏或数据损坏。

    65030

    【DB笔试面试728】在Oracle中,如何修改RAC中的主机名?

    ♣ 题目部分 在Oracle中,如何修改RAC中的主机名? ♣ 答案部分 RAC中的主机名主要有公网对应的主机名、VIP对应的主机名、SCAN对应的主机名和私有主机名。...(一)公网主机名 集群公网对应的主机名是在安装时输入的,并且被记录在OCR中。这个主机名在安装之后是不能修改的。...(二)VIP主机名 集群的VIP对应的主机名是可以被修改的,修改步骤如下所示: 首先停止数据库和相关的VIP资源: srvctl stop db -d lhrac srvctl stop vip -n...修改SCAN的端口号的命令如下所示: srvctl modify scan_listener -p 1522 (四)私有主机名 在11.2 oracle clusterware之前的版本,私有主机名被记录在...但是,在Oracle 11.2 Grid结构中,私有主机名不再被记录在OCR中,并且不存在依赖关系,所以它可以在/etc/hosts文件中任意更改。

    1K20

    Postgresql 理解cache 在 postgres中的意义 与 share buffer 到底设置多大性能最好

    POSTGRESQL 数据库的CACHE 要接受什么,数据,以及索引,这些信息已8KB的块存储在磁盘上,在需要处理的时候,需要将他们读入4KB的为存储单元的CACHE 中。...PG 通过postmaster 为每一个数据库数据的访问分配一个基于他下面的子进程,并且这些进程在访问 share buffer后,基于LRU算法会让这些数据持续的在缓冲中,当这些数据在一定时间不再需要后...我们做一个实验,看看数据在内存中和不再内存中查询的差别(以下实验在传统SATA磁盘系统) 我们灌入5000万的数据到PG的数据库中。通过语句我们可以查出表在内存中的数据块的数量。...通过pg_prewarm 将数据加载进缓存中。 可以看到这次查询的时间仅仅需要2秒钟 执行计划也没有什么不同。此时这就能证明,数据在buffer中 和不再buffer中的巨大区别....pgbench -i --unlogged-tables -s 500 -U postgres -p 5432 -d pgbench 之前写的一篇与这个有关的文字 PostgreSQL 自己的 DB buffer

    2.5K50

    【DB笔试面试562】在Oracle中,如何监控索引的使用状况?

    ♣ 题目部分 在Oracle中,如何监控索引的使用状况?...♣ 答案部分 在开发应用程序时,可能会建立很多索引,那么这些索引的使用到底怎么样,是否有些索引一直都没有用到过,在这种情况下就需要对这些索引进行监控,以便确定它们的使用情况,并为是否可以清除它们给出依据...通过一段时间的监控,就可以确定哪些是无用的索引。...,分析索引的使用情况 可以从视图DBA_HIST_SQL_PLAN中获取到数据库中所有索引的扫描次数情况,然后根据扫描次数和开发人员沟通是否需要保留索引。...从图中可以看到有一个3.6G大的索引在13号到22号从没使用过,接下来,可以继续查询该索引是否是联合索引,创建是否合理,分析为何不走该索引,从而判断是否可以删除索引。

    1.3K20
    领券