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

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

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

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

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

你可能感兴趣的文章
Objective-C实现iterating through submasks遍历子掩码算法(附完整源码)
查看>>
Objective-C实现iterative merge sort迭代归并排序算法(附完整源码)
查看>>
Objective-C实现jaccard similarity相似度无平方因子数算法(附完整源码)
查看>>
Objective-C实现Julia集算法(附完整源码)
查看>>
Objective-C实现jump search跳转搜索算法(附完整源码)
查看>>
Objective-C实现jumpSearch跳转搜索算法(附完整源码)
查看>>
Objective-C实现k nearest neighbours k最近邻分类算法(附完整源码)
查看>>
Objective-C实现k-means clustering均值聚类算法(附完整源码)
查看>>
Objective-C实现k-Means算法(附完整源码)
查看>>
Objective-C实现k-nearest算法(附完整源码)
查看>>
Objective-C实现KadaneAlgo计算给定数组的最大连续子数组和算法(附完整源码)
查看>>
Objective-C实现kadanes卡达内斯算法(附完整源码)
查看>>
Objective-C实现kahns algorithm卡恩算法(附完整源码)
查看>>
Objective-C实现karatsuba大数相乘算法(附完整源码)
查看>>
Objective-C实现karger算法(附完整源码)
查看>>
Objective-C实现KMP搜索算法(附完整源码)
查看>>
Objective-C实现Knapsack problem背包问题算法(附完整源码)
查看>>
Objective-C实现knapsack背包问题算法(附完整源码)
查看>>
Objective-C实现knapsack背包问题算法(附完整源码)
查看>>
Objective-C实现knight tour骑士之旅算法(附完整源码)
查看>>