我有一个最终的非静态成员:
private final HashMap<String,String> myMap;
Run Code Online (Sandbox Code Playgroud)
我想使用构造函数调用的方法初始化它.由于myMap是final,我的"helper"方法无法直接初始化它.我当然有选择:
我可以直接在构造函数中实现myMap初始化代码.
MyConstructor (String someThingNecessary)
{
myMap = new HashMap<String,String>();
myMap.put("blah","blahblah");
// etc...
// other initialization stuff unrelated to myMap
}
Run Code Online (Sandbox Code Playgroud)
我可以让我的帮助器方法构建HashMap,将其返回到构造函数,然后让构造函数将对象分配给myMap.
MyConstructor (String someThingNecessary)
{
myMap = InitializeMyMap(someThingNecessary);
// other initialization stuff unrelated to myMap
}
private HashMap<String,String> InitializeMyMap(String someThingNecessary)
{
HashMap<String,String> initializedMap = new HashMap<String,String>();
initializedMap.put("blah","blahblah");
// etc...
return initializedMap;
}
Run Code Online (Sandbox Code Playgroud)
方法#2很好,但是,我想知道是否有某种方法可以让helper方法直接操作myMap.也许一个修饰符指示它只能由构造函数调用?
MyConstructor (String someThingNecessary)
{
InitializeMyMap(someThingNecessary);
// other initialization stuff unrelated to myMap
}
// helper doesn't work since it can't modify …Run Code Online (Sandbox Code Playgroud) 我主要来自c ++背景,但我认为这个问题适用于任何语言的线程.这是场景:
我们有两个线程(ThreadA和ThreadB),共享内存中有一个值x
假设通过互斥锁(或其他合适的同步控制)适当地控制对x的访问
如果线程碰巧在不同的处理器上运行,如果ThreadA执行写操作会发生什么,但是它的处理器将结果放在其L2缓存中而不是主内存中?然后,如果ThreadB尝试读取该值,它不仅会查看自己的L1/L2缓存/主内存,然后使用旧的值吗?
如果不是这样,那么这个问题是如何管理的?
如果是这样的话,那么可以采取什么措施呢?