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

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

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

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

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

你可能感兴趣的文章
Objective-C实现hornerMethod霍纳法算法(附完整源码)
查看>>
Objective-C实现Horn–Schunck光流算法(附完整源码)
查看>>
Objective-C实现Http Post请求(附完整源码)
查看>>
Objective-C实现http下载文件 (附完整源码)
查看>>
Objective-C实现Http协议下载文件(附完整源码)
查看>>
Objective-C实现huffman哈夫曼编码算法(附完整源码)
查看>>
Objective-C实现ID3贪心算法(附完整源码)
查看>>
Objective-C实现IIR 滤波器算法(附完整源码)
查看>>
Objective-C实现IIR数字滤波器(附完整源码)
查看>>
Objective-C实现insertion sort插入排序算法(附完整源码)
查看>>
Objective-C实现integer partition整数分区算法(附完整源码)
查看>>
Objective-C实现integerPartition整数划分算法(附完整源码)
查看>>
Objective-C实现interpolation search插值搜索算法(附完整源码)
查看>>
Objective-C实现Interpolation search插值查找算法(附完整源码)
查看>>
Objective-C实现intersection交集算法(附完整源码)
查看>>
Objective-C实现intro sort内省排序算法(附完整源码)
查看>>
Objective-C实现inverse matrix逆矩阵算法(附完整源码)
查看>>
Objective-C实现inversions倒置算法(附完整源码)
查看>>
Objective-C实现isalpha函数功能(附完整源码)
查看>>
Objective-C实现islower函数功能(附完整源码)
查看>>