Connect包(一)

JDK1.5提供的一个针对高并发进行的编程的包 阻塞式对列–BlockingQueue

遵循先进先出(FIFO)的原则。阻塞式本身使用的时候是需要指定界限。

1.ArrayBlockingQueue-阻塞式顺序对列
底层是基于数组来进行存储,使用的时候需要指定一个容量,容量在制定之后不可改变。----生产-消费模型,
2.LinkedBlockingQueue–阻塞式链式对列
底层基于链表(节点)来进行数据的存储。在使用的时候可以指定初始容量,也可以不指定。如果制定了容量,就以制定的容量为准来进行存储;如果不指定容量,那么默认容量是Integer.MAX_VALUE -> 2 31 - 1。如果不指定容量,一般认为这个容量是无限的PriorityBlockingQueue-具有优先级的阻塞式对列-如果不指定容量默认容量是11。如果将元素—取出,那么会对元素进行自然排序—要求存储的对象所对应的类必须事先Comparable,重写compareTo方法,将比较规则写到方法中,如果进行迭代遍历,那么不保证排序。
SynchronousQueue—同步对列-只允许存储一个元素。
**

并发映射–ConcurrentMap

HashMap–底层依靠数组——链表存储的数据。默认初始容量是16,默认加载因子是0.75f,默认扩容每次增加一倍。本身是一个异步式线程不安全的映射Hashtable–同步式线程安全的映射—对外提供的方法都是同步方法
ConcurrentHashMap–异步式线程安全的映射–在jdk1.8之前,采用分段(分桶)锁,分段锁采用的是读写锁机制(读锁:允许多个线程读,但是不允许线程写;写锁:允许一个线程写,但是不允许线程读);jdk1.8不在采用锁机制,而是CAS(Compare and Swap)算法,减少了锁的开销;如果一个桶中的元素数超过8个,那么会将这个桶的链表扭转成一颗红黑树(自平衡二叉树)

**

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在打过程中出现"Connection refused: connect"错误通常是由于网络连接问题导致的。这个错误表示无法建立与目标主机的连接。以下是一些可能的解决方法: 1. 检查网络连接:确保你的网络连接正常,并且可以访问目标主机。你可以尝试使用ping命令来测试网络连接是否正常。 2. 检查目标主机的状态:确保目标主机正在运行,并且服务正在监听指定的端口。你可以使用telnet命令来测试是否可以连接到目标主机的指定端口。 3. 检查防火墙设置:如果你的系统上启用了防火墙,确保防火墙允许你的应用程序访问目标主机的指定端口。你可以尝试禁用防火墙或者配置防火墙规则来允许访问。 4. 检查应用程序配置:确保你的应用程序的配置文件中指定的主机名和端口号是正确的。如果你使用的是环境变量或者配置文件来配置主机名和端口号,确保这些配置是正确的。 5. 检查数据库连接配置:如果你的应用程序连接的是数据库,确保数据库连接配置正确。检查数据库的主机名、端口号、用户名和密码是否正确。 6. 检查目标主机的负载:如果目标主机的负载过高,可能会导致连接被拒绝。你可以尝试等待一段时间后再次尝试连接。 这些是一些常见的解决方法,你可以根据具体情况进行尝试。如果问题仍然存在,请提供更多的详细信息,以便我能够给出更准确的解决方案。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值