背景:我开始了一个测试 Swift 项目,以了解和扩展我对如何将 CoreData 实现到我的项目中的知识。当然,每当我只是测试和玩弄代码时,我总是会走岔路,似乎陷入了一些无关紧要的话题。现在是什么时候需要将框架或库直接链接到 XCode 项目。
那么这是怎么来的...我正在创建 NSManagedObject 的子类,我必须在我的 Swift文件。一切似乎都很完美;没有错误、警告等。但是,当我在“项目和目标列表”中检查哪些框架和库链接到我的项目时,没有列出任何框架和库。然后我意识到当你必须 import CoreDataimport UIKit 时也是如此。显然可以选择直接链接这些框架,但似乎没有必要这样做。
至于我的问题,是否存在不必显式链接到 XCode 项目的默认框架,或者当我打包我的项目进行部署时最终是否必须链接这些框架?如果不是这种情况,从更广泛的角度来看,什么时候有必要将框架和库显式链接到 XCode 项目?
编辑***
如果所有 Apple 框架都已经自动链接....那么将它们添加到您的项目中有什么意义呢? (请注意,CoreData.framework 最初并未像图片中那样显式链接。)
最佳答案
没有魔法发生。
这是因为 Xcode(LLVM) 引入了模块和自动链接。
(相关关键字:@import 而不是#import 和build设置选项,如启用模块、自动链接框架,默认情况下,两者都设置为 YES)。
自动地,这两个关键字(模块,自动链接标志选项)组合尝试查找并添加任何相关的所有支持模块的框架。
从 Xcode 5(实际上是 LLVM 和 clang 编译器前端)开始,在内部,具有上述默认项目设置的 LLVM 已经使用模块系统通过 @import/#import 语句自动链接代码中的任何框架。
一旦框架自动与之关联,开发人员就无需再将它们放入 Linked Frameworks & Libraries 中。
所以,这就是为什么 Apple 系统框架(默认框架)不必显式链接到 Xcode 项目的原因。
由于该模块在Xcode中可用,因此无需继续导入.pch文件(预编译前缀头)中的所有系统框架列表。 所以,这就是为什么 pch setup 也设置为 NO 并且在后台默认不需要。
据我所知,到目前为止,这些限制仅适用于 Apple 系统框架,这意味着它不能应用于用户框架和其他 C/C++ 库。
希望对您有所帮助。
关于ios - 什么时候必须将框架和库链接到 XCode 项目?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33728359/
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby
我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
它不等于主线程的binding,这个toplevel作用域是什么?此作用域与主线程中的binding有何不同?>ruby-e'putsTOPLEVEL_BINDING===binding'false 最佳答案 事实是,TOPLEVEL_BINDING始终引用Binding的预定义全局实例,而Kernel#binding创建的新实例>Binding每次封装当前执行上下文。在顶层,它们都包含相同的绑定(bind),但它们不是同一个对象,您无法使用==或===测试它们的绑定(bind)相等性。putsTOPLEVEL_BINDINGput
我在我的Rails项目中使用Pow和powifygem。现在我尝试升级我的ruby版本(从1.9.3到2.0.0,我使用RVM)当我切换ruby版本、安装所有gem依赖项时,我通过运行railss并访问localhost:3000确保该应用程序正常运行以前,我通过使用pow访问http://my_app.dev来浏览我的应用程序。升级后,由于错误Bundler::RubyVersionMismatch:YourRubyversionis1.9.3,butyourGemfilespecified2.0.0,此url不起作用我尝试过的:重新创建pow应用程序重启pow服务器更新战俘
我可以得到Infinity和NaNn=9.0/0#=>Infinityn.class#=>Floatm=0/0.0#=>NaNm.class#=>Float但是当我想直接访问Infinity或NaN时:Infinity#=>uninitializedconstantInfinity(NameError)NaN#=>uninitializedconstantNaN(NameError)什么是Infinity和NaN?它们是对象、关键字还是其他东西? 最佳答案 您看到打印为Infinity和NaN的只是Float类的两个特殊实例的字符串
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象