分布式Java中间件

image

关键词:java线程

ZERO

    持续更新 请关注:https://zorkelvll.cn/blogs/zorkelvll/articles/2018/11/18/1542543273257

背景

中间件是为软件应用提供操作系统所提供的服务之外的服务的,如远程过程调用和对象访问中间件、消息中间件、数据访问中间件

一、Java线程

线程操作的jvm内存是主内存和工作内存这两个概念的!!!

1、**线程池:**有效复用线程而不用每次都创建线程,ThreadPoolExecutor、ScheduledThreadPoolExecutor(定时)、Executors.newCachedThreadPool(没有线程上限)

2、**可见性:**指在一个线程中修改变量的值之后,在其他线程中能够看到这个值

2、**synchronized关键字:**声明方法(静态方法则同步锁属于类、成员方法则同步锁属于对象)、代码块(该关键字后的参数,用于同步的锁所属的对象,可以是任意对象) =>(线程间互斥作用、块中变量的可见性作用【**在主内存与工作内存中同步变量的值,因此是可见的**】)【**独占锁】**

3、**ReentrantLock类**:类似于修饰代码块时的syschronized,不过需要**显示地进行unlock**(一般写在finally中);另有tryLock方法,且构造函数可选择构造公平锁(严格按照顺序,所以效率相对低些)与非公平锁(可抢占,可能会导致饿死);ReentrantReadWriteLock读写锁,主要用于读多写少且读不需要互斥的场景

4、**volatile关键字:**只是保证所修饰的同一个变量在多线程中的可见性,常用于修饰作为开关状态的变量;同一个变量线程间的可见性与多个线程中操作互斥是两码事;**【显示锁和原子变量】**

对于一般的变量,如**get方法**的调用获取的都是当前线程工作内存中的**副本**,因此**读**不一定是最新的值;

被volatile修饰的变量,变量不会有线程的本地副本,只会放在主存中,因此**读**一定是最新的;

被sychronized修饰的变量,则是可以保证线程的本地副本与主存的同步,因此**读**也一定是最新的;

5、**Atomic*类:**提供一些原子操作,比较明显地提升性能,主要在于如AtomicInteger内部通过JNI的方式使用了硬件支持的CAS指令;

6、**wait、notify、notifyAll方法:**均是Object对象的方法,wait是进行等待的,notify和notify都是唤醒调用同一个对象wait方法的线程,区别在于前者唤醒一个等待线程而后者唤醒全部,,且这**三个方法的调用都必须在sychronized块中**

7、CountDownLatch类:当多个线程都到达了预期状态或完成预期工作时触发事件,其他线程可以等待这个事件来触发自己后续的工作;

8、CyclicBarrier类:循环屏障,可以协同多个线程并让多个线程在这个屏障前等待,直到所有线程都到达了这个屏障时,再一起继续执行后面的动作;

9、Semaphore类:用于管理信号量的,构造的时候传入可供管理的信号量的数值,总数也即控制并发的数量

10、Exchanger类:用于在两个线程之间进行数据交换

11、**Future接口和FutureTask类:**回调

二、并发容器:

并发容器是线程安全的一种,但是更加强调的是容器的并发性,也即不仅仅只追求线程安全,还要考虑并发性,提升并发环境下的性能;

**加锁互斥:**线程安全,但降低了并发性,其实就是串行了

**CopyOnWrite:**是在更改容器的时候,把容器写一份进行修改,保证正在读的线程不受影响,适合于读多写少的场景会非常好,实质上在**写的时候重建了一次容器**

**Concurrent:**实现思路是尽量**保证读不加锁,并且修改时不影响读**,所以会达到比使用读写锁更高的并发性能

三、动态代理:

代理模式

静态代理

动态代理:Proxy.newProxyInstance()     invoke()

四、反射

Java反射机制是指在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性

五、网络通信

三个模型:BIO、NIO、AIO

通信框架:MINA,Netty

【读书系列】

《大型网站系统与Java中间件实践》,曾宪杰,电子工业出版社
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,692评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,482评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,995评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,223评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,245评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,208评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,091评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,929评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,346评论 1 311
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,570评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,739评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,437评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,037评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,677评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,833评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,760评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,647评论 2 354

推荐阅读更多精彩内容

  • 在一个方法内部定义的变量都存储在栈中,当这个函数运行结束后,其对应的栈就会被回收,此时,在其方法体中定义的变量将不...
    Y了个J阅读 4,416评论 1 14
  • Java8张图 11、字符串不变性 12、equals()方法、hashCode()方法的区别 13、...
    Miley_MOJIE阅读 3,701评论 0 11
  • 一. Java基础部分.................................................
    wy_sure阅读 3,810评论 0 11
  • 这次全国范围的流感,以为朋友圈疯了,原来真是全国性质,洁身自好的好,少窜人堆,注意卫生,谣传比肩非典,怎么不去死,...
    纵情嬉戏天地间阅读 233评论 0 0
  • 今天的努力是为了将来不费力,并不是不努力,只要活着就有责任跟重担,不为谁,为自己这一生。 不论是工作上的努力,爱情...
    爱疯儿阅读 170评论 0 0