I was surprised to find that this condition is always true:
let foo: Any = 4
if let object = foo as? AnyObject {
print(\"It\'s an object.\")
//do som
The code I have shown below is reported as not working in release build. (Please see Paul Cantrell's comment below.)
Apologies for my "as far as I tested" was too limited.
I'll update this answer when I find some further info about this.
I'm not sure we can see this behaviour in the next beta (or GM or Released version...), but this works as you expect in Xcode 8 beta 6.
let foo: Any = 4
if type(of: foo) is AnyClass {
print("It's an object.")
let object = foo as AnyObject
//do something with `object` that requires reference semantics
} else {
print("It's not an object.") //->It's not an object.
}
class MyClass {}
let bar: Any = MyClass()
if type(of: bar) is AnyClass {
print("It's an object.") //->It's an object.
let object = foo as AnyObject
//do something with `object` that requires reference semantics
} else {
print("It's not an object.")
}
let baz: Any = Array<AnyObject>()
if type(of: baz) is AnyClass {
print("It's an object.")
let object = foo as AnyObject
//do something with `object` that requires reference semantics
} else {
print("It's not an object.") //->It's not an object.
}
I cannot check all possible cases, so there may be some edge cases where this does not work. But as far as I tested, this seems to work as expected.
Perhaps you want to look at Mirror
which allows a degree of introspection. Documentation is here
import Foundation
func prettyPrint(_ any: Any) -> String {
let m = Mirror(reflecting: any)
switch m.displayStyle {
case .some(.class): // ****
return "Class"
case .some(.collection):
return "Collection, \(m.children.count) elements"
case .some(.tuple):
return "Tuple, \(m.children.count) elements"
case .some(.dictionary):
return "Dictionary, \(m.children.count) elements"
case .some(.set):
return "Set, \(m.children.count) elements"
case .some(.optional):
return "Optional"
case .some(.enum):
return "Enum"
case .some(.struct):
return "Struct"
default:
return "\(String(describing: m.displayStyle))"
}
}
class A {}
prettyPrint([1, 2, 3]) // "Collection, 3 elements"
prettyPrint(Set<String>()) // "Set, 0 elements"
prettyPrint([1: 2, 3: 4]) // "Dictionary, 2 elements"
prettyPrint((1, 2, 3)) // "Tuple, 3 elements"
prettyPrint(3) // "nil"
prettyPrint("3") // "nil"
prettyPrint(NSObject()) // "Class"
prettyPrint(NSArray(array:[1, 2, 3])) // "Collection, 3 elements"
prettyPrint(A()) // "Class"
// prettyPrint(nil) // Compile time error "Nil is not compatible with Any