关于 weakSelf 的几种写法

本文详细解析了Swift中ARC与Block的使用场景及注意事项,特别针对AFNetworking源码中的写法进行了解释,并指出不同写法对代码执行的影响。通过对比分析,帮助开发者正确理解和应用这些特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文地址:点击打开链接

原文地址:点击打开链接

前言

在不久前看AFNetworking的源码时候发现了这么一句:

1
2
3
4
5
6
7
8
9
10
// 不知道这行代码的使用场景的同学你该去自习看看ARC的注意事项和Block的使用了
// AFNetworking的写法
__weak __typeof(&*self)weakSelf = self;

// 我之前一直这么写的
__weak __typeof(self) weakSelf = self;
// 或者这么写
__weak XxxViewController *weakSelf = self;
// 或者这么写
__weak id weakSelf = self;

当时也没注意为什么要写成&*这种样子… 今天再想起来, 搜了一圈, 终于让我找到原因了…

正文

其实以上的4种写法都是对的 
AFNetworking里面不写成以上这行代码的原因是因为 typeof(self) 会被解析成 XxxViewController *const __strong (假如你的self是XxxViewController的话), 这样的话就就会报错…(没有老版本, 没有验证, 不过看网上的结论应该是这样了)

不过, 如果你写成了__typeof(self)也没什么问题… 那是因为在LLVM3.1之后已经不会出现以上的情况了… ( via )

总结

React Router 是 React 应用程序中用于处理客户端路由的流行库。它支持多种路由模式,主要有以下几种常见的写法: 1. **基本路由(BrowserRouter)**:这是最基础的路由,基于 HTML5 的 History API。`<Router>` 组件通常包含 `<Route>` 子组件,每个 `<Route>` 标记了一个特定的 URL。例如: ```jsx import { BrowserRouter as Router, Route } from 'react-router-dom'; function App() { return ( <Router> <Route path="/" component={Home} /> <Route path="/about" component={About} /> </Router> ); } ``` 2. **Hash Router**:当浏览器不支持 HTML5 History API 时,可以使用 Hash Router,通过 URL 中的哈希片段 (#) 来表示路由。写法类似: ```jsx import { HashRouter, Route } from 'react-router-dom'; function App() { return ( <HashRouter> <Route path="/" exact component={Home} /> <Route path="/about" component={About} /> </HashRouter> ); } ``` 3. **Memory Router**:内存路由器只在单页应用内部有效,适用于无状态组件之间的导航。它并不实际改变 URL,而是维护组件树的状态。例如: ```jsx import { MemoryRouter } from 'react-router-dom'; function App() { return ( <MemoryRouter> <Switch> <Route path="/" component={Home} /> <Route path="/about" component={About} /> </Switch> </MemoryRouter> ); } ``` 4. **Link组件和NavLink组件**:除了 `<Route>`,还有专用的 `<Link>` 和 `<NavLink>` 组件,用于创建可点击的链接,自动匹配当前路由。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值