Swift项目进口框架,Xcode(Import Framework in Swift Project, Xcode)
我试图将我的
myFramework
导入一个项目。 我已经在构建阶段添加了我的框架 - >使用库链接二进制。Objective-C作品:
#import <UIKit/UIKit.h> #import <myFramework/myFramework.h>
但是在Swift中,我得到一个
No such module myFramework
错误:import UIKit import myFramework
根据Swift文档 :
导入外部框架
您可以导入具有纯Objective-C代码库,纯Swift代码库或混合语言代码库的外部框架。 导入外部框架的过程与框架是用单一语言编写还是包含两种语言的文件相同。 导入外部框架时,请确保将要导入的框架的“定义模块”构建设置设置为“是”。
您可以使用以下语法将框架导入到不同目标中的任何Swift文件中:
迅速
import FrameworkName
您可以使用以下语法将框架导入到不同目标中的任何Objective-C .m文件中:
Objective-C的
@import FrameworkName;
我使用Xcode 5创建了
myFramework
5没有“定义模块”构建设置。哪里有问题?
I'm trying to import
myFramework
into a project. I've addedmyFramework
in Build Phases->Link Binary With Libraries.Objective-c works:
#import <UIKit/UIKit.h> #import <myFramework/myFramework.h>
But with in Swift, I get a
No such module myFramework
error:import UIKit import myFramework
According to the Swift documentation:
Importing External Frameworks
You can import external frameworks that have a pure Objective-C codebase, a pure Swift codebase, or a mixed-language codebase. The process for importing an external framework is the same whether the framework is written in a single language or contains files from both languages. When you import an external framework, make sure the Defines Module build setting for the framework you’re importing is set to Yes.
You can import a framework into any Swift file within a different target using the following syntax:
SWIFT
import FrameworkName
You can import a framework into any Objective-C .m file within a different target using the following syntax:
OBJECTIVE-C
@import FrameworkName;
I created
myFramework
using Xcode 5. Xcode 5 doesn't have a "Defines Module" build setting.Where is the problem?
原文:https://stackoverflow.com/questions/24057756
最满意答案
忽略安装位,您的脚本:
- 开始交易
- 删除
- 插入
- 运行一些生成错误的代码
- 做一个
COMMIT
因此,当然这些初步变化已经应用。 您可以设置
XACT_ABORT
,这将导致生成错误的任何批处理回滚事务,但您仍需要非常小心:create table T(ID int) go set xact_abort on go begin transaction go insert into T(ID) values (1) go alter table T add ID int null go insert into T(ID) values (2) go commit go select * from T
生成以下消息:
(1 row(s) affected) Msg 2705, Level 16, State 4, Line 1 Column names in each table must be unique. Column name 'ID' in table 'T' is specified more than once. (1 row(s) affected) Msg 3902, Level 16, State 1, Line 1 The COMMIT TRANSACTION request has no corresponding BEGIN TRANSACTION. (1 row(s) affected)
并且表中仍然有一行包含
2
。 为什么? 因为错误通过回滚终止了事务,但是下一批(包含insert into T(ID) values (2)
)运行时没有显式事务存在。 除了一些手动步骤之外, 在批量处理错误处理方面没有太多帮助,例如:create table T(ID int) go set xact_abort on go begin transaction go insert into T(ID) values (1) go alter table T add ID int null go if @@TRANCOUNT = 0 goto errored insert into T(ID) values (2) errored: go if @@TRANCOUNT = 0 goto errored commit errored: go select * from T
并且您必须在每个包含错误的批次中执行相同的操作。
Ignoring the setup bit, your script:
- starts a transaction
- does a delete
- does an insert
- runs a bit of code that generates an error
- does a
COMMIT
So, of course those initial changes have applied. You can set
XACT_ABORT
on which will cause any batch that generates an error to rollback the transaction, but you still need to be very careful:create table T(ID int) go set xact_abort on go begin transaction go insert into T(ID) values (1) go alter table T add ID int null go insert into T(ID) values (2) go commit go select * from T
Produces these messages:
(1 row(s) affected) Msg 2705, Level 16, State 4, Line 1 Column names in each table must be unique. Column name 'ID' in table 'T' is specified more than once. (1 row(s) affected) Msg 3902, Level 16, State 1, Line 1 The COMMIT TRANSACTION request has no corresponding BEGIN TRANSACTION. (1 row(s) affected)
And still has a row containing
2
in the table. Why? Because the error terminated the transaction with a rollback, but then the next batch (containinginsert into T(ID) values (2)
) was run without an explicit transaction existing. There's not much help you can get when it comes to error handling across batches, except some manual steps, e.g.:create table T(ID int) go set xact_abort on go begin transaction go insert into T(ID) values (1) go alter table T add ID int null go if @@TRANCOUNT = 0 goto errored insert into T(ID) values (2) errored: go if @@TRANCOUNT = 0 goto errored commit errored: go select * from T
And you'll have to do the same in every batch that might follow one containing errors.
相关问答
更多-
错误:无法在只读事务中执行CREATE TABLE(ERROR: cannot execute CREATE TABLE in a read-only transaction)[2022-10-25]
通常这种错误最可能的原因是: 尝试在只读副本上创建语句(整个实例是只读的)。将default_transaction_read_only设置为ON 数据库将default_transaction_read_only设置为ON 所提到的脚本的第一行有: CREATE DATABASE exercises; \c exercises CREATE SCHEMA cd; 并且您在第6行报告错误发生在CREATE SCHEMA之前,而不是之前。 这意味着CREATE DATABASE在 这个上下文中的“用户进程”指的是在客户端机器上运行的进程,该进程创建与Oracle的连接。 换句话说,如果您正在使用应用程序A( SQL*Plus ,TOAD等)连接到Oracle,则用户进程是SQL*Plus ,TOAD等。如果该用户进程在您处于交易,该交易将被回滚。 只要PMON发现客户端已经死亡并且可能需要一些时间,这种情况就会发生 - 对于Oracle来说,区分用户进程和用户进程的故障并不总是微不足道的,此时此刻。 "User process" in this context is referrin ...忽略安装位,您的脚本: 开始交易 删除 插入 运行一些生成错误的代码 做一个COMMIT 因此,当然这些初步变化已经应用。 您可以设置XACT_ABORT ,这将导致生成错误的任何批处理回滚事务,但您仍需要非常小心: create table T(ID int) go set xact_abort on go begin transaction go insert into T(ID) values (1) go alter table T add ID int null go insert into T( ...摘自博客 : 当您的交易达到16级错误时,交易可能会进入注定状态(XACT_STATE()= -1),但并不总是如上所述!! 以下是博客中给出的一些例子: --datatype conversion errors: DECLARE @GUID UNIQUEIDENTIFIER SELECT @GUID = CONVERT(UNIQUEIDENTIFIER, 'ABC') ---divide by zero errors: SELECT * FROM my_books WHERE ...Spring回滚事务部分(Spring rollback transaction part)[2022-06-19]
我用annotaion @Transactional(propagation = Propagation.REQUIRES_NEW)为cretePartA()方法解决了问题,并尝试了/ catch块 I solved it with annotaion @Transactional(propagation = Propagation.REQUIRES_NEW) for cretePartA() method and try/catch block我通过在Mysql中创建一个存储过程并从我的Java程序中调用它来解决了这个问题。 I resolved the problem by making a stored procedure in Mysql and call it from my Java program.您正在将实体SavegeojsonEntity保存到postgresql数据库,此错误意味着: Caused by: org.postgresql.util.PSQLException: ERROR: column "vectortype" of relation "savegeojson" does not exist Position: 76 SavegeojsonEntity映射到的表没有列vectortype 。 检查数据库中的列是否存在于表中。 如果它不存在,则需要将该列添加到表中。 ...Django多个数据库和“无法在只读事务中执行”错误(Django multiple databases and “cannot execute in a read-only transaction” error)[2022-07-20]
你试过以下吗? 这是从Django文档页面中复制出来的: import random class MasterSlaveRouter(object): def db_for_read(self, model, **hints): """ Reads go to a randomly-chosen slave. """ return random.choice(['slave1', 'slave2']) def db_for_ ...这意味着该表被独占锁定并处于交易状态。 在回滚或提交之前,您不能截断 It means that the table is exclusively locked and is under transaction. You cannot truncate until it is rollbacked or committed正如我从您的问题中所理解的,您可以使用插件使其变得简单和模块化。 将其添加到utils.js const customPlugin = {} customPlugin.install = (Vue, options) => { Vue.prototype._isMobile = () => { return $(window).width() < 768 } } export default customPlugin 然后在你的main.js你可以像任何其他插件一样使用它: impor ...相关文章
更多- python top project of 2013
- AMF: ASP.NET Mobile Framework
- 千锋首发Swift视频教程
- Swift入门视频教程-尚学堂视频教程
- IOS-Social.framework
- 安卓应用程序插件化开发框架 -AAP Framework
- Spring Project Annotations
- pychseg - A Python Chinese Segment Project - Google Project Hosting
- Using Lucene's new QueryParser framework in Solr
- 【z】Storm - the world's best IDE framework for .NET
最新问答
更多- 您如何使用git diff文件,并将其应用于同一存储库的副本的本地分支?(How do you take a git diff file, and apply it to a local branch that is a copy of the same repository?)
- 将长浮点值剪切为2个小数点并复制到字符数组(Cut Long Float Value to 2 decimal points and copy to Character Array)
- OctoberCMS侧边栏不呈现(OctoberCMS Sidebar not rendering)
- 页面加载后对象是否有资格进行垃圾回收?(Are objects eligible for garbage collection after the page loads?)
- codeigniter中的语言不能按预期工作(language in codeigniter doesn' t work as expected)
- 在计算机拍照在哪里进入
- 使用cin.get()从c ++中的输入流中丢弃不需要的字符(Using cin.get() to discard unwanted characters from the input stream in c++)
- No for循环将在for循环中运行。(No for loop will run inside for loop. Testing for primes)
- 单页应用程序:页面重新加载(Single Page Application: page reload)
- 在循环中选择具有相似模式的列名称(Selecting Column Name With Similar Pattern in a Loop)
- System.StackOverflow错误(System.StackOverflow error)
- KnockoutJS未在嵌套模板上应用beforeRemove和afterAdd(KnockoutJS not applying beforeRemove and afterAdd on nested templates)
- 散列包括方法和/或嵌套属性(Hash include methods and/or nested attributes)
- android - 如何避免使用Samsung RFS文件系统延迟/冻结?(android - how to avoid lag/freezes with Samsung RFS filesystem?)
- TensorFlow:基于索引列表创建新张量(TensorFlow: Create a new tensor based on list of indices)
- 企业安全培训的各项内容
- 错误:RPC失败;(error: RPC failed; curl transfer closed with outstanding read data remaining)
- C#类名中允许哪些字符?(What characters are allowed in C# class name?)
- NumPy:将int64值存储在np.array中并使用dtype float64并将其转换回整数是否安全?(NumPy: Is it safe to store an int64 value in an np.array with dtype float64 and later convert it back to integer?)
- 注销后如何隐藏导航portlet?(How to hide navigation portlet after logout?)
- 将多个行和可变行移动到列(moving multiple and variable rows to columns)
- 提交表单时忽略基础href,而不使用Javascript(ignore base href when submitting form, without using Javascript)
- 对setOnInfoWindowClickListener的意图(Intent on setOnInfoWindowClickListener)
- Angular $资源不会改变方法(Angular $resource doesn't change method)
- 在Angular 5中不是一个函数(is not a function in Angular 5)
- 如何配置Composite C1以将.m和桌面作为同一站点提供服务(How to configure Composite C1 to serve .m and desktop as the same site)
- 不适用:悬停在悬停时:在元素之前[复制](Don't apply :hover when hovering on :before element [duplicate])
- 常见的python rpc和cli接口(Common python rpc and cli interface)
- Mysql DB单个字段匹配多个其他字段(Mysql DB single field matching to multiple other fields)
- 产品页面上的Magento Up出售对齐问题(Magento Up sell alignment issue on the products page)