小编csj*_*csj的帖子

在Java中,可以从构造函数助手初始化final字段吗?

我有一个最终的非静态成员:

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)

java constructor final initialization

42
推荐指数
2
解决办法
2万
查看次数

线程系统如何处理由不同cpu缓存的共享数据?

我主要来自c ++背景,但我认为这个问题适用于任何语言的线程.这是场景:

  1. 我们有两个线程(ThreadA和ThreadB),共享内存中有一个值x

  2. 假设通过互斥锁(或其他合适的同步控制)适当地控制对x的访问

  3. 如果线程碰巧在不同的处理器上运行,如果ThreadA执行写操作会发生什么,但是它的处理器将结果放在其L2缓存中而不是主内存中?然后,如果ThreadB尝试读取该值,它不仅会查看自己的L1/L2缓存/主内存,然后使用旧的值吗?

如果不是这样,那么这个问题是如何管理的?

如果是这样的话,那么可以采取什么措施呢?

multithreading caching multiprocessor

11
推荐指数
1
解决办法
920
查看次数