`
zuoge85
  • 浏览: 80384 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

并发的最低安全性

    博客分类:
  • java
阅读更多

并发最低安全性

 

例如在某些实时性统计的时候我们只需要这种最低安全性保障就够了,

 

在多线程并发的情况下.基本类型和引用都能保证最低安全性.

但是在32位jre的情况下long和double是不能保证这种安全性的...可能会读取到严重的错误值,例如读取到了2次不同更新的高32位和低32位的组合值!

 

补充,其实CopyOnWriteArray也是一种保证最低安全性然后获得性能提升的办法

 

 

下面是一个测试在32位系统上,非常快就能输出error:3333333355555555,

而在64位系统没有这种问题.可以给变量加上volatile修饰符获得这种最低安全性!

 

 

package sb.test;

import java.util.Arrays;

/**
 * jvm参数 -server -verbose:gc -Xms1024m -Xmx1536m
 * 
 * @author zuoge85
 * 
 */
public class VolatileTest {
	private static final int THREAD_NUMS = 4;
	private static final long NUMS = 10000000000000000l;

	public static void main(String[] args) {
		try {
			test();
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
	}

	private static  long value = 0;
	private static final long[] values = {0x3333333333333333l,0x4444444444444444l,0x5555555555555555l,0x6666666666666666l};
	private static void test() throws InterruptedException {
		Thread[] ts = new Thread[THREAD_NUMS];
		for (int i = 0; i < ts.length; i++) {
			final int n = i;
			ts[i] = new Thread() {
				public void run() {
					for (int j = 0; j < NUMS; j++) {
						value = values[n];
					}
				}
			};
		}
		Thread readThread = new Thread(){
			public void run() {
				while(true){
					long v = value;
					if(Arrays.binarySearch(values, value) >=0){
						
					}else{
						System.out.println("error:"+Long.toHexString(v));
					}
				}
			}
		};
		for (int i = 0; i < ts.length; i++) {
			ts[i].start();
		}
		readThread.start();
		for (int i = 0; i < ts.length; i++) {
			ts[i].join();
		}
		readThread.stop();
		readThread.join();
		System.out.println(value);
	}
}

 

 

 

 

 

0
7
分享到:
评论

相关推荐

    java并发编程实践笔记

    11. **最低限的安全性:** 即使没有同步,读取未同步变量的线程至少能看到之前写入的值。这是一种最低限的安全性保证,但对于数值运算并不适用。 12. **Volatile变量的局限性:** `volatile`变量只能确保可见性,不...

    数据库并发操作

    数据库并发操作是数据库管理系统在处理多个用户同时访问和操作数据时的一种机制。...通过深入学习并发控制理论,并结合实践经验,我们可以更好地设计和管理数据库,确保数据的安全性和服务的可靠性。

    Java并发编程实战1

    对于64位的`double`和`long`变量,不保证最低安全性,可能需要额外的同步措施。在编写并发代码时,使用`volatile`应谨慎,避免在复杂场景下使用,以防止难以理解和调试的问题。 总结来说,Java并发编程要求开发者...

    redis百万并发访问数据库测试

    8. **Redis的复制和主从模式**:通过主从复制,可以创建多个Redis实例作为从节点,分散读取压力,提高服务的可用性和并发处理能力。主从模式下,写操作在主节点执行,从节点同步数据并处理只读请求。 9. **Redis ...

    海量并发微服务框架设计.pptx

    调度亲和性策略会选择负载最低的节点进行任务分配,而故障节点隔离与恢复则确保了系统的健壮性。"Power of Two Choices"算法借鉴了Nginx、Envoy、Finagle和Linkerd等负载均衡器的设计,通过比较两个候选节点的性能...

    基于指令级冗余的密码流处理器并发错误检测方法.pdf

    通过引入指令级冗余,并优化复制策略,可以在不显著增加系统负担的情况下,增强对并发错误的检测能力,从而提高系统的整体安全性。 总的来说,这篇论文提出的基于指令级冗余的并发错误检测方法,结合脆弱性感知的...

    高并发平台架构规划方案..pdf

    5. 安全性:结构上的安全及主机的安全策略。 6. 易维护性:通过简单的操作就能维护庞大的集群系统。 7. 低成本:前期尽量在有限的硬件资源下,利用软件提高性能。 架构组件: 1. 硬件:Web服务器集群、缓存...

    数据库系统并发控制及其实现

    在多用户环境下的数据库操作中,确保数据的一致性、完整性和安全性成为了一项挑战。本文将基于提供的内容,深入探讨并发控制的理论基础,分析并发访问引起数据不一致的原因,并研究在分布式数据库系统中实现并发控制...

    达芬奇机器人在妇科手术应用中的安全性评价.pdf

    此外,对于恶性肿瘤患者来说,淋巴结切除数目和术后并发症的发生情况(包括出血、感染、尿潴留、肠梗阻、下肢深静脉血栓等)是评价手术安全性的另一个重要方面。文中还特别提到了总住院时间作为衡量手术安全性的一个...

    浅析MYSQL中的并发操作与锁定

    MYSQL中的并发操作和锁定机制是非常重要的概念,它们可以确保数据库的数据一致性和安全性。但是,如果不正确地使用锁定机制,可能会导致锁竞争的问题。因此,在实际应用中,需要小心地设计和实施锁定机制,以确保...

    48 多个事务并发更新以及查询数据,为什么会有脏写和脏读的问题?l.pdf

    为了保证数据库的事务操作既高效又安全,需要合理地配置隔离级别和使用锁机制,并结合事务日志来确保数据的一致性和完整性。在实际应用中,开发者还需要根据具体的业务需求和系统负载情况来平衡并发控制的严格程度和...

    多线程和并发基础

    - Java提供了多种并发工具类,如`ExecutorService`、`CountDownLatch`、`CyclicBarrier`等,用于简化多线程编程过程中的复杂性。 #### 四、实践建议 - 牢固掌握Java多线程基础知识是应对面试及日常开发的基础。 -...

    行业-57 停一停脚步:梳理一下数据库的多事务并发运行的隔离机制l.rar

    数据库是现代信息系统的核心,它负责存储、管理和处理数据。...总的来说,数据库的多事务并发运行隔离机制是保证数据完整性和一致性的重要手段,理解并合理运用这些机制对于优化数据库性能和保障数据安全具有重要意义。

    数据库期末模拟试题

    根据给定的文件内容,我们可以总结出以下有关数据库的关键知识点:...综上所述,这些知识点涵盖了数据库的基础概念、数据模型、安全性、并发控制、规范化等多个方面,对于学习数据库管理和应用的学生来说是非常重要的。

    平台设计方案.doc

    数据库设计遵循了标准化、跨平台性、并发处理能力、数据安全性和恢复能力的原则,选择了MS SQL Server(集群)作为数据库平台,使用标准SQL语句,并利用数据库建模工具构建结构。数据库系统采用主备方式,数据实时...

    聚合易支付系统开源版 可运营无加密版

    - **安全性**:为了保障交易的安全性,系统内置了多种安全机制,如防SQL注入、XSS攻击等防护措施,同时还支持SSL/TLS加密传输,有效保护用户的资金安全和个人隐私。 - **易用性**:系统界面友好,操作简便,无论是...

    信息安全服务软件使用说明书.pdf

    3. 预检结果准确,系统安全性经过多方面优化,包括网络安全、数据传输、访问和存储安全。 3.1 硬件环境: - 服务器端:基于Intel CPU,或同等AMD型号,最低4GB内存。 - 客户端:Core i3-2100 3.10GHz CPU,4GB内存...

    redis面试准备.docx

    AOF策略有三种同步选项:always(每次修改都同步,效率最低)、everysec(每秒同步一次,平衡性能与安全性)和no(不进行同步,效率最高)。 在实际应用中,Redis官方推荐同时使用RDB和AOF策略,以兼顾数据安全性和...

    T+运行环境及服务器配置[借鉴].pdf

    这些操作系统专为服务器环境设计,提供更好的安全性、稳定性和性能,能够满足T+软件的运行需求。 3. 客户端配置: 对于客户端计算机,基本配置要求包括至少双核的CPU(如Intel Core 2 Duo T6670 @ 2.20GHz),内存...

Global site tag (gtag.js) - Google Analytics