- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
对于我的 EVReflection库 我遇到了一个 EKEvent 的镜像没有返回任何信息的情况。即使在完成基础知识时,Mirror 也没有返回任何东西。当您在 Mirror 行之后设置断点时,您会看到 Mirror 对象中没有任何内容。这是错误还是我遗漏了什么?
更新:我扩展了使用旧的 Objective C objc_property_t 和 property_getName 函数获取属性的演示。它将返回一个属性列表。但是当你得到 .value(forKey:
#if os(tvOS)
// Eventkit is not supported on tvOS
#else
import XCTest
import Foundation
import EventKit
let store = EKEventStore()
class EVReflectionEventKitTests: XCTestCase {
func testEventKit() {
let exp = expectation(description: "eventStore")
store.requestAccess(to: .event, completion: { (granted, error) in
let event = EKEvent(eventStore: store)
event.startDate = Date().addingTimeInterval(10000)
event.title = "title"
event.location = "here"
event.endDate = Date().addingTimeInterval(20000)
event.notes = "notes"
event.calendar = store.defaultCalendarForNewEvents
event.addAlarm(EKAlarm(absoluteDate: Date().addingTimeInterval(10000)))
//WARNING: You will get events in your agenda! Disable next line if you don't want that
//try? store.save(event, span: EKSpan.thisEvent, commit: true)
let m = Mirror(reflecting: event)
print("mirror children = \(m.children.count)")
let oc = self.properties(event)
print(oc)
for p in oc {
var value: Any? = nil
value = event.value(forKey: p)
print("\(p) = \(String(describing: value))")
}
exp.fulfill()
})
waitForExpectations(timeout: 10) { error in
XCTAssertNil(error, "\(error?.localizedDescription ?? "")")
}
}
func properties(_ classToInspect: NSObject) -> [String] {
var count = UInt32()
let classToInspect = NSURL.self
let properties = class_copyPropertyList(classToInspect, &count)
var propertyNames = [String]()
let intCount = Int(count)
for i in 0 ..< intCount {
let property : objc_property_t = properties![i]!
guard let propertyName = NSString(utf8String: property_getName(property)) as String? else {
debugPrint("Couldn't unwrap property name for \(property)")
break
}
propertyNames.append(propertyName)
}
free(properties)
return propertyNames
}
}
#endif
最佳答案
这似乎是有意为之的行为:
_ObjCMirror
child count implementation只是遵从 _getObjCCount
shim,它的实际函数名称是 specified作为 swift_ObjCMirror_count
。swift_ObjCMirror_count
当 REFLECT_OBJC_IVARS
被定义为错误值时,被设置为始终返回 0
。REFLECT_OBJC_IVARS
的值是多少?没错,就是set to 0
. 如果它不为零,它会转储 ivars,而不是属性。属性的 getter 属性可以做到这一点,因此没有与属性名称匹配的方法,并且它的支持 ivar 也可以与属性命名不同,如果有的话:这两者都可能导致 -valueForKey:
失败。大多数类不会禁用通过键值编码直接访问 ivar,因此您可能想尝试转储 ivar 并访问它们。
您可能还想注意到一些类在其布局方面存在缺陷,例如 NSURL
,was explicitly blacklisted from reflection即使为 Obj-C 类启用了反射!
预计到达时间:这是一个转储 ivar 的示例。不幸的是,它在这种情况下并不是很有用。
根据ivars生成字典的代码:
func makeDictionary(describing object: AnyObject) -> Dictionary<String, Any> {
var dict = [String: Any]()
guard let cls = object_getClass(object) else {
print("object has no class:", object)
return dict
}
var ivarCount: UInt32 = 0
guard let ivarsPtr: UnsafeMutablePointer<Ivar?> = class_copyIvarList(cls, &ivarCount), ivarCount > 0
else {
print("object has no ivars, or failed to get any:", object)
return dict
}
let ivars = UnsafeBufferPointer(start: ivarsPtr, count: numericCast(ivarCount))
for ivar in ivars {
guard let int8Ptr = ivar_getName(ivar) else {
print("failed to get name for ivar:", ivar as Any)
continue
}
let name = String(cString: int8Ptr)
let value = object_getIvar(object, ivar)
print("value for \(name):", value as Any)
dict[name] = value ?? object.value(forKey: name) ?? NSNull()
}
return dict
}
以及按照您的问题中所述创建的事件的输出(手动硬包装以便于查看):
dictionary version based on direct ivar access:
["isYearlessLeapMonthBirthday": 0
, "_birthdayPersonID": 0
, "_sliceDate": <null>
, "nameForBirthday": <null>
, "_futureLocalUidForSliceChild": <null>
, "isYearlessBirthday": 0
, "_cachedDuration": <null>
, "_cachedStartOfDayForStartDate": <null>
, "_isPhantom": 0
, "lunarCalendarString": <null>
, "_cachedIsMultiDayTimedEvent": <null>
, "_cachedTimeValuesCalendar": <null>
, "birthdayTitle": <null>
, "_cachedStartOfDayForEndDate": <null>
, "_cachedDaysSpanned": <null>
, "_cachedJunkStatus": 0
, "sliceParentID": <null>
, "participantsStatus": 0
]
关于swift - EKEvent的镜像不显示数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43686690/
我需要将 OCI 镜像 list 转换为 Docker v2.2 镜像格式,反之亦然。但我找不到两者之间的任何区别,是否有任何实际区别或它们相同? 最佳答案 Docker 镜像 list V 2,模式
LNMP 是代表 Linux 系统下的 Nginx、Mariadb、PHP 相结合而构建成的动态网站服务器架构。下面使用docker制作分布式lnmp 镜像。 1、docker 分布式 lnmp
你好,我创建了一个基础镜像;但是,每当我运行 docker build . 时,我都看不到成功构建 我的 docker 文件 FROM centos:7 ARG user=john ARG home=
我想要我的 iPhone 应用程序中有一个功能,可以将图像转换为类似镜像的方式。 就像如果有一个左手举起的人的图像,那么转换后的图像必须有右手举起的同一个人。 任何代码或链接将不胜感激 预先感谢您的帮
我们希望将一个Elasticsearch集群放置在kubernetes集群的顶部(当前有2个节点,但是我们计划增加它)。 是否可以通过使集群中的每个节点包含相同数据的方式配置elasticsearch
我试图了解 docker 如何在文件系统上存储图像和图层。构建图像时,图层出现在 /var/lib/docker/image/overlay2/layerdb 中,图像出现在 /var/lib/doc
所以我最近开始使用 docker,因为我认为让我的网站 dockerised 会很好。我有一个 super 简单的 docker-compose.yml 文件,其中仅包含 wordpress:late
我有一个 docker 镜像,叫它 dockerimage/test。每次我更新它时,我都会增加一个标签,所以 dockerimage/test:1、dockerimage/test:2 等等。 当我
我开始使用 Docker,我发现我可以将主图像存储库放在不同的磁盘上(符号链接(symbolic link)/var/lib/docker 到其他位置)。 但是,现在我想看看是否有办法将它拆分到多个磁
显然应用程序打包和部署似乎有两种做法 创建 Docker 镜像并部署它 从头开始构建和部署应用程序。 我对如何使用选项 1) 感到困惑。前提是你获取一个 docker 镜像并在任何平台上重复使用它。但
我有一个 UIView具有透明背景和一些按钮。我想捕获 View 的绘图,将其缩小,然后在屏幕上的其他位置重新绘制(镜像)它。 (在另一个 View 之上。)按钮可以更改,因此它不是静态的。 最好的方
我正在为一个项目编写测试,我想测试和验证一个 docker 镜像构建。但我不想推送图像。 我希望图像构建在 CI(如 taskcluster)上并运行测试。 最佳答案 您需要使用 taskcluste
我想复制每个 html 页面中的代码,同时添加一些更改: 例子: Any text (even if includes :., 输出: Any text (even if includes :.,
我使用三星 ARM Cortex A9 Exynos4412 板。我在板上启动“linux + Qt”img。但是板上没有包管理器,也没有 make 、 gcc 命令。在/bin 文件中有文件 Bus
是否有可能以某种方式设置一个 git 存储库,该存储库像通常的 --mirror 一样用于 pull 入它,但在将从推送到另一个存储库时没有强制? 最佳答案 您可以像这样添加 --no-force 来
背景 最近在巡检过程中,发现harbor存储空间使用率已经达到了80%。于是,去看了一下各项目下的镜像标签数。发现有个别项目下的镜像标签数竟然有好几百个。细问之下得知,该项目目前处于调试阶段
以下均在centos 7进行的操作 docker安装 ? 1
我知道如何删除 N 天前创建的旧 Docker 镜像。 See here 但我真正想做的是删除过去 N 天未使用的旧 Docker 镜像。 目标是保留经常使用的图像,即使在我进行清理时没有容器实际使用
我有一个自定义的 docker 镜像,已经构建好了。没有可用的 Dockerfile。在容器内部,可以使用自定义用户,而不是 root,比如 test。此用户已附加到组 test。这是容器的默认用户。
我有一个开发数据库,我想将其提交到 docker 镜像中,然后推送到私有(private)存储库并用于本地开发和 CI 构建。 数据库保存为SQL备份,我可以通过将备份文件映射到官方镜像的/doc
我是一名优秀的程序员,十分优秀!