上海-拼多多电商部二面(1)

简介: 上海-拼多多电商部二面(1)

1 、并发编程三要素?


(1)原子性


原子性指的是一个或者多个操作,要么全部执行并且在执行的过程中不被其他操作打断,要么就全部都不执行。


(2)可见性


可见性指多个线程操作一个共享变量时,其中一个线程对变量进行修改后,其他线程可以立即看到修改的结果。


(3)有序性


有序性,即程序的执行顺序按照代码的先后顺序来执行。


2 、实现可见性的方法有哪些?


(1)发挥多核 CPU 的优势


多线程,可以真正发挥出多核 CPU 的优势来,达到充分利用 CPU 的目的,采用多线程的方式去同时完成几件事情而不互相干扰。


(2)防止阻塞


从程序运行效率的角度来看,单核 CPU 不但不会发挥出多线程的优势,反而会因为在单核CPU 上运行多线程导致线程上下文的切换,而降低程序整体的效率。但是单核 CPU 我们还是要应用多线程,就是为了防止阻塞。试想,如果单核 CPU 使用单线程,那么只要这个线程阻塞了,比方说远程读取某个数据吧,对端迟迟未返回又没有设置超时时间,那么你的整个程序在数据返回回来之前就停止运行了。多线程可以防止这个问题,多条线程同时运行,哪怕一条线程的代码执行读取数据阻塞,也不会影响其它任务的执行。


(3)便于建模


这是另外一个没有这么明显的优点了。假设有一个大的任务 A,单线程编程,那么就要考虑很多,建立整个程序模型比较麻烦。但是如果把这个大的任务 A 分解成几个小任务,任务 B、任务C、任务 D,分别建立程序模型,并通过多线程分别运行这几个任务,那就简单很多了。


4 、创建线程的有哪些方式?


(1)继承 Thread 类创建线程类


(2)通过 Runnable 接口创建线程类


(3)通过 Callable 和 Future 创建线程


(4)通过线程池创建


5、创建线程的三种方式的对比


(1)采用实现 Runnable、Callable 接口的方式创建多线程。


优势是:


线程类只是实现了Runnable 接口或 Callable 接口,还可以继承其他类。在这种方式下,多个线程可以共享同一个 target 对象,所以非常适合多个相同线程来处理同一份资源的情况,从而可以将 CPU、代码和数据分开,形成清晰的模型,较好地体现了面向对象的思想。


劣势是:


编程稍微复杂,如果要访问当前线程,则必须使用 Thread.currentThread()方法。


(2)使用继承 Thread 类的方式创建多线程


优势是:


编写简单,如果需要访问当前线程,则无需使用 Thread.currentThread()方法,直接使用 this即可获得当前线程。


劣势是:


线程类已经继承了Thread 类,所以不能再继承其他父类。


(3)Runnable 和 Callable 的区别


a、Callable 规定(重写)的方法是 call(),Runnable 规定(重写)的方法是 run()。


b、Callable 的任务执行后可返回值,而 Runnable 的任务是不能返回值的。


c、Call 方法可以抛出异常,run 方法不可以。


d、运行 Callable 任务可以拿到一个 Future 对象,表示异步计算的结果。它提供了检查计算是否完成的方法,以等待计算的完成,并检索计算的结果。通过 Future 对象可以了解任务执行情况,可取消任务的执行,还可获取执行结果。


目录
相关文章
|
9月前
|
算法 安全 Java
五面蚂蚁、三面拼多多、字节跳动最终拿offer入职拼多多
文章有点长,请耐心看完,绝对有收获!不想听我BB直接进入面试分享: 准备过程 蚂蚁金服面试分享 拼多多面试分享 字节跳动面试分享 总结
|
云栖大会
《2018广东云栖大会——地产行业分论坛-易行》电子版地址
2018广东云栖大会——地产行业分论坛-易行
75 0
《2018广东云栖大会——地产行业分论坛-易行》电子版地址
2023年五面蚂蚁、三面拼多多、字节跳动最终拿offer入职拼多多
文章有点长,请耐心看完,绝对有收获!不想听我BB直接进入面试分享: 准备过程 蚂蚁金服面试分享 拼多多面试分享 字节跳动面试分享 总结 说起来开始进行面试是年前倒数第二周,上午9点,我还在去公司的公交上,突然收到蚂蚁的面试电话,其实算不上真正的面试。面试官只是和我聊了下他们在做的事情(主要是做双十一这里大促的稳定性保障,偏中间件吧),说的很详细,然后和我沟通了下是否有兴趣,我表示有兴趣,后面就收到正式面试的通知,最后没选择去蚂蚁表示抱歉。
|
存储 XML SQL
阿里巴巴2021春招二面(淘宝商家平台实习生)
支付的时候提交订单以后会调用远程支付接口,比如支付宝,如何保证在复杂的网络环境下不会重复支付? 商城平台都有物流追踪功能,如果现在某个订单平台上已经显示物流配送完毕,订单结束,但这时物流公司比较拉跨,过了一段时间又发过来了这个物流信息显示正在配送中,应该怎么办?
|
缓存 Java 调度
上海-拼多多电商部二面(2)
上海-拼多多电商部二面(2)
87 0
上海-拼多多电商部二面(2)
|
新零售
农村淘宝、天猫小店、零售通、城市合伙人概念太多傻傻分不清,到底该怎么区别理解和加盟?
农村淘宝、天猫小店、零售通、城市合伙人概念太多傻傻分不清,到底该怎么区别理解和加盟?
409 0
农村淘宝、天猫小店、零售通、城市合伙人概念太多傻傻分不清,到底该怎么区别理解和加盟?
|
设计模式 缓存 算法
互联网大厂考点(阿里+百度+腾讯+字节跳动+美团+京东)
- 01 互联网大厂考点(阿里+百度+腾讯+字节跳动+美团+京东) - 02 Java 面试考点大全(基本功底+常用技术+技术深度+技术经验+学习能力+工作能力+项目经验) - 03 面试真题重现
303 0
|
安全 算法 Java
上海-拼多多电商部二面(4)
上海-拼多多电商部二面(4)
151 0
|
安全 Java
上海-拼多多电商部二面(3)
上海-拼多多电商部二面(3)
100 0
|
小程序
杭州马拉松要来了,今年用支付宝就能快速报名!
用户只需要在支付宝搜索“杭马”就找到杭马官方小程序,可以在小程序中找到比赛时间、赛程、路线、报名费和一些参加细则等内容
1467 12