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

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

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

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

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

你可能感兴趣的文章
Objective-C实现LinearSieve线性素数筛选算法 (附完整源码)
查看>>
Objective-C实现LinkedListNode链表节点类算法(附完整源码)
查看>>
Objective-C实现LinkedList链表算法(附完整源码)
查看>>
Objective-C实现local weighted learning局部加权学习算法(附完整源码)
查看>>
Objective-C实现logistic regression逻辑回归算法(附完整源码)
查看>>
Objective-C实现logistic sigmoid函数(附完整源码)
查看>>
Objective-C实现longest Common Substring最长公共子串算法(附完整源码)
查看>>
Objective-C实现longest increasing subsequence最长递增子序列算法(附完整源码)
查看>>
Objective-C实现longestCommonSubsequence最长公共子序列算法(附完整源码)
查看>>
Objective-C实现LongestIncreasingSubsequence最长递增子序列算法(附完整源码)
查看>>
Objective-C实现lorenz transformation 洛伦兹变换算法(附完整源码)
查看>>
Objective-C实现Lower-Upper Decomposition上下分解算法(附完整源码)
查看>>
Objective-C实现LowerCaseConversion小写转换算法(附完整源码)
查看>>
Objective-C实现lowest common ancestor最低共同祖先算法(附完整源码)
查看>>
Objective-C实现LRU 缓存算法(附完整源码)
查看>>
Objective-C实现LRU缓存(附完整源码)
查看>>
Objective-C实现LRU(least recently used)算法(附完整源码)
查看>>
Objective-C实现lstm prediction预测算法(附完整源码)
查看>>
Objective-C实现lucas数列算法(附完整源码)
查看>>
Objective-C实现Luhn (Mod 10)Algorithm算法(附完整源码)
查看>>