block常见的几个问题

block的理解

block是一个指向结构体的指针,编译器会将block的内部代码生成对应的函数

一,block与变量

1)可以修改全部变量和静态变量

2)不可以修改局部变量,如果想要修改使用__block

注意:block之所以能够修改全局变量和局部变量与使用__block修饰的局部变量,是因为把指向变量的指针copy到block结构体内部.而布局变量是copy的变量值到block内部.

二,block与copy属性

block的内存是放在栈中,不需要程序员去管理,什么时候释放内存也不是程序员可以决定的,当我们想要block时,就需要使用copy属性,会把block copy到堆上.在ARC中,对block代码块内部的对象强引用.在飞ARC中对于引用对象进行一次retain操作.

三,block与循环引用

在block代码块内部如果使用了当前对象进行调用方法,或者他的的操作,就会对当前对象进行强引用一次.使得当前对象又引用了当前对象.而不能正常释放.

使用__weak来修饰可以避免对控制器或者当前类的循环引用.

WTViewController *__weak weakSelef = self;

四,block与内存管理

1.block的内存默认是在栈中(开发人员不需要去管理block内存),在block内部引用的对象,如果做一次release操作就可以释放,block不会对所引用对象进行任何操作

2.如果对block进行了copy操作(block的内存会搬到堆里面),在block内部引用的对象引用计数加1 .它会对所引用的对象做一次retain操作.如果在非ARC中block外部使用__block修饰所引用的对象,在ARC中使用__unsafe_unretained(或者__weak)修饰引用的对象,就不会做retain操作

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现在几个问题之间进行切换的常见页面,你可以使用JavaScript来实现这个功能。以下是一个示例: ```html <!DOCTYPE html> <html> <head> <title>见问题</title> <style> /* CSS样式可以在这里定义 */ </style> <script> function showQuestion(questionId) { // 隐藏所有问题的内容 var questions = document.getElementsByClassName("question"); for (var i = 0; i < questions.length; i++) { questions[i].style.display = "none"; } // 显示选中问题的内容 var question = document.getElementById(questionId); question.style.display = "block"; } </script> </head> <body> <h1>常见问题</h1> <ul> <li><a href="#" onclick="showQuestion('question1')">账户问题</a></li> <li><a href="#" onclick="showQuestion('question2')">订单问题</a></li> <li><a href="#" onclick="showQuestion('question3')">支付问题</a></li> <!-- 添加更多问题的链接 --> </ul> <div id="question1" class="question"> <h2>账户问题</h2> <ul> <li>如何注册账户?</li> <li>如何修改密码?</li> <li>如何找回忘记的用户名或密码?</li> </ul> </div> <div id="question2" class="question" style="display: none;"> <h2>订单问题</h2> <ul> <li>如何下订单?</li> <li>如何取消订单?</li> <li>如何查看订单状态?</li> </ul> </div> <div id="question3" class="question" style="display: none;"> <h2>支付问题</h2> <ul> <li>支持哪些支付方式?</li> <li>支付安全性如何?</li> <li>如何申请退款?</li> </ul> </div> <!-- 添加更多问题的内容 --> </body> </html> ``` 在这个示例中,我们使用JavaScript定义了一个`showQuestion`函数,它会根据传入的问题ID显示对应的问题内容,并隐藏其他问题的内容。通过在问题链接上添加`onclick`事件,调用`showQuestion`函数并传入对应的问题ID,就可以实现在不同问题之间进行切换。初始状态下,只显示第一个问题的内容,其他问题的内容通过设置`display: none;`来隐藏。你可以根据需要添加更多问题,并在页面中进行相应的修改和调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值