高并发编程技术点.pdf

  1. 1、本文档共32页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

⾼并发编程技术点

线程

Thread类

java.lang.Thread类,API中该类中定义了有关线程的⼀些⽅法,具体如下:

构造⽅法:

publicThread():分配⼀个新的线程对象。

publicThread(Stringname):分配⼀个指定名字的新的线程对象。

publicThread(Runnabletarget):分配⼀个带有指定⽬标新的线程对象。

publicThread(Runnabletarget,Stringname):分配⼀个带有指定⽬标新的线程对象并指定名字。

常⽤⽅法:

publicStringgetName():获取当前线程名称。

publicvoidstart():导致此线程开始执⾏;Java虚拟机调⽤此线程的run⽅法。

publicvoidrun():此线程要执⾏的任务在此处定义代码。

publicstaticvoidsleep(longmillis):使当前正在执⾏的线程以指定的毫秒数暂停(暂时停⽌执

⾏)。

publicstaticThreadcurrentThread():返回对当前正在执⾏的线程对象的引⽤。

线程状态

java线程创建

1、实现runnable接⼝和继承Thread

继承Thread类和实现Runnable接⼝本质上是没有区别的最终都是调⽤start()⽅法来新建线程

他们的区别就是:

①实现runnable

@Override

publicvoidrun(){

if(target!=null){

target.run();

}

}

是调⽤target.run()

②继承Thread类是重写整个run⽅法。

③从代码架构⻆度:具体实现应该和创建任务分离开来进⽽实现代码解耦

④继承Thread类每次创建都要新建⼀个任务这⽆形之中会带来很⼤得消耗

⼤量的线程创建、执⾏和销毁是⾮常耗cpu和内存的,这样将直接影响系统的吞吐量,导致性能急剧

下降,如果内存资源占⽤的⽐较多,还很可能造成OOM。

⑤java只能单继承,因此如果是采⽤继承Thread的⽅法,那么在以后进⾏代码重构的时候可能会遇到

问题,因为⽆法继承别的类了。

线程安全

线程安全三个特性:原⼦性,可⻅性,⼀致性。

•原⼦性:原⼦性,即⼀个操作或多个操作要么全部执⾏并且执⾏的过程不会被任何因素打断,要么

就都不执⾏。

•可⻅性:是指当多个线程访问同⼀个变量时,⼀个线程修改了这个变量的值,其他线程能够⽴即看

得到修改的值。显然,对于单线程来说,可⻅性问题是不存在的。

•有序性:有序性即程序执⾏的顺序按照代码的先后顺序执⾏。

“共享”意味着变量可以由多个线程同时访问,“可变”意味着变量的值在⽣命周期内可以发⽣变

化。加锁只是控制访问的⼀种⼿段。

synchroized,voliatile,lock,原⼦变量(atomicvariable),countDownLatch。

多实例部署时候,可借助中间件(redis、zookeeper)来保证不同实例之间的线程安全,也可借助

mysql特性来保证。

1.什么是线程安全

1当多个线程访问某个⽅法时,不管你通过怎样的调⽤⽅式或者说这些线程如何交替的执⾏,

2我们在主程序中不需要去做任何的同步,都不需要进⾏额外的处理,这个类的结果⾏为都是我们设想的正

确⾏为,那么我们就可以说这个类时线程安全的(同⼀时间给主播转账,应该是所有⼈打赏的⾦额之

和)

2.各种需要考虑线程的安全情况

1.访问共享的变量或者资源会有并发⻛险⽐如对象的属性静态变量共享缓存数据库等

2.所有依赖时序的操作即使每⼀步操作都是线程安全的还是存在并发问题:read-modify-write

,check-then-act(检查后⾏动)

3.不同数据之间存在捆绑关系的时候(ip和端⼝号进⾏原⼦合并操作)

4.我们使⽤其他类的时候如果对⽅没有声明⾃⼰是线程安全的⽐如hashmap就提醒是线程不安全的

我们就知道要使⽤安全的mapConcurrentHashMap

3.为什么会有线程性能问题

由于线程需要协作所以引起调度当你线程的数量⼤于cpu的数量的时候系统就会进⾏分配与调度

文档评论(0)

易油科技首席架构师 + 关注
实名认证
服务提供商

精通系统架构设计,能够设计可扩展、高效、安全的系统。 面对复杂问题时,能够运用创造性思维找到解决方案。 带领团队落地多个大型项目。

1亿VIP精品文档

相关文档