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

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

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

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

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

你可能感兴趣的文章
Objective-C实现qubit measure量子位测量算法(附完整源码)
查看>>
Objective-C实现Queue队列算法(附完整源码)
查看>>
Objective-C实现Queue队列算法(附完整源码)
查看>>
Objective-C实现quick select快速选择算法(附完整源码)
查看>>
Objective-C实现rabin-karp算法(附完整源码)
查看>>
Objective-C实现radians弧度制算法(附完整源码)
查看>>
Objective-C实现radianToDegree弧度到度算法(附完整源码)
查看>>
Objective-C实现radix sort基数排序算法(附完整源码)
查看>>
Objective-C实现rail fence围栏密码算法(附完整源码)
查看>>
Objective-C实现randomized heap随机堆算法(附完整源码)
查看>>
Objective-C实现rayleigh quotient瑞利商算法(附完整源码)
查看>>
Objective-C实现RC4加解密算法(附完整源码)
查看>>
Objective-C实现RC4加解密算法(附完整源码)
查看>>
Objective-C实现recursive bubble sor递归冒泡排序算法(附完整源码)
查看>>
Objective-C实现recursive insertion sort递归插入排序算法(附完整源码)
查看>>
Objective-C实现recursive quick sort递归快速排序算法(附完整源码)
查看>>
Objective-C实现RedBlackTree红黑树算法(附完整源码)
查看>>
Objective-C实现redis分布式锁(附完整源码)
查看>>
Objective-C实现regular-expression-matching正则表达式匹配算法(附完整源码)
查看>>
Objective-C实现relu线性整流函数算法(附完整源码)
查看>>