Type 'AnyObject' does not conform to protocol 'SequenceType'

前端 未结 2 1882
眼角桃花
眼角桃花 2020-12-16 09:44
func loadThumbnails() {

    let paths = NSSearchPathForDirectoriesInDomains(NSSearchPathDirectory.DocumentDirectory, NSSearchPathDomainMask.UserDomainMask, true)
           


        
相关标签:
2条回答
  • 2020-12-16 10:43

    Apple states in The Swift Programming Language:

    The for-in loop performs a set of statements for each item in a range, sequence, collection, or progression.

    Right now, directoryContent is just conforming to protocol AnyObject, so you can't use for loops over it. If you want to do so, you have to do something similar to the following:

    for item in directoryContent as [AnyObject] {
        //Do stuff
    }
    
    0 讨论(0)
  • 2020-12-16 10:50

    contentsOfDirectoryAtPath returns an NSArray, whereas you are casting it to AnyObject. The solution is to cast it to either [AnyObject]? or NSArray:

    let directoryContent: [AnyObject]? = fileManager.contentsOfDirectoryAtPath(documentsDirectory, error: &error)
    

    or

    let directoryContent: NSArray? = fileManager.contentsOfDirectoryAtPath(documentsDirectory, error: &error)
    

    Then use an optional binding before the for loop:

    if let directoryContent = directoryContent {
        for item:AnyObject in directoryContent {
    

    Looking at the contentsOfDirectoryAtPath documentation, it states it always returns an array - so what said above can be reduced to unwrapping the return value to either a swift or objc array, with no need to use the optional binding:

    let directoryContent: [AnyObject] = fileManager.contentsOfDirectoryAtPath(documentsDirectory, error: &error)!
    

    or

    let directoryContent: NSArray = fileManager.contentsOfDirectoryAtPath(documentsDirectory, error: &error)!
    
    0 讨论(0)
提交回复
热议问题