/// 编码对象为 json 字符串 /// /// - Parameter obj: 需要被编码的对象 /// - Returns: 编码后的 json 字符串 private func encode<T : Encodable>(obj: T) -> String? { let encoder = JSONEncoder() guard let data = try? encoder.encode(obj) else { return nil } return String(data: data, encoding: String.Encoding.utf8) }
这里有一个方法,对实现了 Encodable 的类型的数据进行编码,实际情况是传递过来的数据类型是 Any,
private func test(data: Any) { //1,这里不可以 if data is Encodable { //调用 encode(obj: data as! Encodable) } else { print("不支持的参数格式") } // 2.swift 这样写也是错误的 guard let d = data as? Encodable else { return } encode(obj: d) }
这两种写法都是错误的,cannot invoke 'encode' with an argument list of type '(obj:Encodable)'
那么我应该怎么判断这个 Any 类型的 data 并把他转化为可以交给 encode ()使用的方式。
![]() | 1 gbammc 2017-10-10 14:52:48 +08:00 你需要把 data 转为一个实现 Encodable 的类型( class,struct 或其它)再传给 encode 方法。 |
![]() | 2 ainopara 2017-10-11 21:58:02 +08:00 via iPhone encode 方法接受的参数是一个类 /结构体 /枚举的实例。并且要求这个类型必须符合 Encodable 协议。<T: Encodable>(obj: T) 这和直接传一个符合 Encodable 协议的对象 (obj:Encodable) 的区别是,编译器在编译的时候就可以知道都有哪些遵循 Encodable 协议的类型有可能被使用到,并为其生成相关数据。 所以你在类型转换的时候需要直接转换到具体要的那个类型而不是一个泛泛的 Encodable 协议。所有会作为参数传进来的类型都应该有对应的判断,是不是很麻烦?要我说一开始就不应该把类型信息擦掉,不要让对方传个 Any 给你就没这问题了。 |