常用的几种单例写法

前言:公司倒闭了重新找工作,开始各种面试,那就回答面试题吧,问的知识点也知道,但就是说出去让面试官觉得很乱,希望通过写技术点博客来锤炼自己吧(刚开始写,会有点乱,加油)。
单例模式:高频面试题。一旦被问到,就直接回答“单例模式就是整个工程中保证只有一个实例,无论何时何地获取。”
单例的写法:

1.最基本的写法

+(instancetype)sharedInstance {
    static Dog *dog = nil;
    if (dog == nil) {
        dog = [[Dog alloc] init];
    }
    return dog;
}

2.考虑线程安全

+ (instancetype)sharedInstance {
    static Dog *dog = nil;
    @synchronized(self) {
        if (!dog) {
            dog = [[Dog alloc] init];
        }
    }
    return dog;
}

虽然了添加了线程锁,但是每次都有取锁过程,很耗性能。
3.使用dispatch_once

+ (instancetype)sharedInstance {
    static Dog *dog = nil;
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken,^{
        dog = [[Dog alloc] init];
    });
    return dog;
}

推荐使用这种。使用GCD满足了线程安全问题,又可以节省时间和性能。
小结:
这只是单例的用法,再去学学单例为什么这样用。

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、付费专栏及课程。

余额充值