博客
关于我
java面试题之能创建volatile数组吗?
阅读量:325 次
发布时间:2019-03-04

本文共 276 字,大约阅读时间需要 1 分钟。

在多线程编程中,volatile关键字常被用来保护共享内存区域的数据。在单线程情况下,一个指向数组的引用只是数组的起始地址,引用本身并不会包含整个数组的内容。所以当引用被重新赋值时,只是指向了另一个数组。这种情况下,原有的数组引用会失效,而新指向的数组则成为当前引用所指的目标。这种方式可以有效防止由于引用失效导致的错误。

不过,当多个线程同时修改同一个数组时,volatile关键字就无法发挥保护作用。因为即使是volatile变量,也无法防止不同的线程同时修改数组中的不同位置导致的竞态条件。这种情况下,必须采用更严格的互斥机制来保证数组的安全性。

转载地址:http://tnbh.baihongyu.com/

你可能感兴趣的文章
oracle 去重
查看>>
oracle 可传输的表空间:rman
查看>>
Oracle 启动监听命令
查看>>
Oracle 启动阶段 OPEN
查看>>
Oracle 在Drop表时的Cascade Constraints
查看>>
Oracle 在Sqlplus 执行sql脚本文件。
查看>>
Oracle 如何处理CLOB字段
查看>>
oracle 学习
查看>>
oracle 定义双重循环例子
查看>>
ORACLE 客户端工具连接oracle 12504
查看>>
Oracle 客户端连接时报ORA-01019错误总结
查看>>
oracle 导出sql数据库表结构,使用sql developer 导出Oracle数据库中的表结构
查看>>
oracle 嵌套表 例子,Oracle之嵌套表(了解)
查看>>
Oracle 常用命令
查看>>
Oracle 常用的V$视图脚本(二)
查看>>
Oracle 并行原理与示例总结
查看>>
oracle 并集 时间_Oracle集合运算符 交集 并集 差集
查看>>
Oracle 序列sequence 开始于某个值(10)执行完nextval 发现查出的值比10还小的解释
查看>>
ORACLE 异常错误处理
查看>>
oracle 执行一条查询语句,把数据加载到页面或者前台发生的事情
查看>>