Attempt to present VC whose view is not in the window hierarchy 解决

本文解析了一个常见的iOS开发警告:尝试在一个不在窗口层级中的控制器上模态显示另一个控制器。通过示例代码解释了如何避免这一问题。

具体的问题如下:

2016-04-11 10:03:01.603 312312321[4377:61862] Warning:
Attempt to present <UIViewController: 0x7fbe686a8690> on <ViewController: 0x7fbe6a024e00>
whose view is not in the window hierarchy!


这个警告曾经遇到过,说实话,当时对于刚入门iOS的我来讲,挺崩溃的,因为不知道为什么就报这个警告了,今天有朋友遇到这个问题,帮他解决了,就在这里记录一下过程,也为了能够帮助遇到相同问题却不知道问题出在哪里的小伙伴。

这个警告一般是在一个控制器调用下面方法,以模态形式跳转至一个新的控制器的时候报的

- (void)presentViewController:(UIViewController *)viewControllerToPresent 
                     animated: (BOOL)flag 
                   completion:(void (^ __nullable)(void))completion NS_AVAILABLE_IOS(5_0);


简单的翻译一下警告,就是说

不在window最上方的控制器视图(用户看到的界面控制器)模态弹出另一个控制器


稍微理解下,就是说在模态弹出的控制器堆栈中,不是栈顶的控制器执行了方法:presentViewController:

用代码稍微理解下:

- (void)viewDidLoad {
    [super viewDidLoad];

    //初始化第一个被模态跳出的控制器
    UIViewController * v1 = [[UIViewController alloc]init];
    v1.view.backgroundColor = [UIColor yellowColor];

    //初始化第二个被模态跳出的控制器
    UIViewController * v2 = [[UIViewController alloc]init];
    v2.view.backgroundColor = [UIColor greenColor];

    //模态跳出第一个控制器
    [self presentViewController:v1 animated:true completion:nil];

    //延迟2s后跳出第二个控制器,此时window最顶层的控制器是v1
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{

        //此时的self不是栈顶
        [self presentViewController:v2 animated:true completion:nil];

    });

    // Do any additional setup after loading the view, typically from a nib.
}


这时控制台不满意了:

2016-04-11 10:03:01.603 312312321[4377:61862] Warning:
Attempt to present <UIViewController: 0x7fbe686a8690> on <ViewController: 0x7fbe6a024e00>
whose view is not in the window hierarchy!


所以遇到这种问题,就是检查一下自己的代码,是因为出现了上面类似的层次问题。Good Luck!

<think>好的,用户遇到了报错“temp is not a file in the archive”,需要解决这个问题。首先,我需要理解这个错误通常发生在什么情况下。根据经验,这个错误通常在使用压缩文件处理库时出现,比如Python的zipfile模块。当尝试访问或提取一个在压缩包中不存在的文件时,就会抛出这样的错误。 接下来,我需要考虑用户可能的情况。用户可能在尝试解压一个名为temp的文件,但压缩包里并没有这个文件,或者路径写错了。比如,用户可能使用了错误的文件名,或者文件路径中有多余的斜杠或目录结构。例如,用户可能写了'folder/temp',但实际上文件直接位于压缩包的根目录下,名为temp。 另外,也有可能用户在使用某些库或工具时,没有正确指定文件路径,或者压缩包本身的结构有问题。例如,某些压缩工具可能在创建压缩包时包含了隐藏的目录结构,导致用户预期的文件路径与实际不符。 接下来,我需要思考如何验证这些可能性。首先,用户应该检查压缩包中的实际文件列表,确认temp是否存在。这可以通过代码列出所有文件,或者手动打开压缩包查看。如果不存在,用户需要确认文件名是否正确,或者是否拼写错误。 如果文件确实存在,但路径不同,比如在子目录中,用户需要调整路径。例如,如果文件实际路径是'subdir/temp',那么用户需要指定完整的路径。此外,还要注意不同操作系统对路径分隔符的处理,比如在Windows中是反斜杠,而Python中通常使用正斜杠。 另外,用户可能误将目录当作文件来提取。例如,压缩包中有一个名为temp的目录,但用户尝试作为文件提取,这也会导致错误。这时候需要确认temp是文件还是目录。 还有一些其他可能性,比如文件权限问题,或者压缩包损坏,但根据错误信息,最可能的问题还是文件不存在或路径错误。 接下来,我需要总结解决步骤,并给出示例代码。首先,用户应该列出压缩包中的所有文件,确认temp是否存在。如果存在,检查路径是否正确。然后,使用正确的路径提取文件。如果不存在,需要检查原始压缩包或文件名是否正确。 同时,需要考虑跨平台路径处理,使用os.path模块来处理路径,避免硬编码分隔符。此外,异常处理也很重要,确保在文件不存在时能够捕获异常并给出提示,而不是让程序崩溃。 最后,可能需要指导用户如何正确构建文件路径,或者在代码中添加调试步骤,比如打印压缩包中的文件列表,帮助用户确认问题所在。</think>当出现`'temp is not a file in the archive'`错误时,说明在解压或访问压缩文件时系统未找到名为`temp`的文件。以下是分步解决方案: --- ### **根本原因分析** 1. **文件名错误**:压缩包中不存在名为`temp`的文件 2. **路径不匹配**:文件实际路径包含子目录(如`folder/temp`) 3. **文件类型混淆**:`temp`可能是一个文件夹而非文件 4. **压缩包损坏**:文件索引信息异常(较少见) --- ### **解决方案流程** #### **步骤1:验证文件是否存在** ```python import zipfile with zipfile.ZipFile("your_archive.zip", 'r') as zip_ref: # 打印压缩包内所有文件路径 print("压缩包内容清单:") zip_ref.printdir() # 关键:验证temp是否在列表中 # 获取所有文件名(含路径) file_list = zip_ref.namelist() print("\n完整文件列表:\n", file_list) ``` #### **步骤2:路径修正方法** - **情形1:文件实际路径为`subdir/temp`** ```python # 提取带路径的文件 zip_ref.extract("subdir/temp", "目标路径") ``` - **情形2:需要模糊匹配文件名** ```python # 查找包含"temp"关键字的文件 target_files = [f for f in file_list if "temp" in f] if target_files: print("找到相似文件:", target_files) else: print("无相关文件") ``` #### **步骤3:安全提取操作** ```python import os try: with zipfile.ZipFile("your_archive.zip") as zip_file: # 建议添加路径标准化处理 target_path = os.path.normpath("temp") # 处理不同OS的路径符号 zip_file.getinfo(target_path) # 显式检查文件是否存在 zip_file.extract(target_path) except KeyError as e: print(f"错误详情:{str(e)}") print("→ 解决方案:检查文件名是否包含隐藏字符(如空格、特殊符号)") except Exception as e: print("其他异常:", str(e)) ``` --- ### **常见修复场景** | 场景 | 表现 | 修复方法 | |------|------|----------| | 大小写敏感系统 | 寻找`Temp`但文件名为`temp` | 使用`lower()`统一转小写匹配 | | 隐藏字符 | 文件名含不可见字符 | 用`repr(file_name)`显示原始字符串 | | 嵌套目录结构 | 文件路径为`data/temp.csv` | 使用完整相对路径提取 | --- ### **扩展建议** 1. **使用校验哈希**:解压前验证压缩包完整性 ```python import hashlib with open("your_archive.zip", "rb") as f: print("SHA256:", hashlib.sha256(f.read()).hexdigest()) ``` 2. **自动重试机制**(适用于网络下载的压缩包) ```python for attempt in range(3): try: # 解压操作 break except zipfile.BadZipFile: print(f"第{attempt+1}次重试...") ``` --- **最终验证**:若操作后仍报错,建议: 1. 使用7-Zip/WinRAR手动验证压缩包结构 2. 检查文件权限设置(特别是Linux/Mac系统) 3. 重新下载或获取原始压缩文件副本
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值