首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Update Map对象,该对象在init()内初始化,该值来自sql表

Update Map对象,该对象在init()内初始化,该值来自sql表
EN

Stack Overflow用户
提问于 2013-09-14 23:10:41
回答 1查看 90关注 0票数 0

嗨,我有Map,它从MySQL表中获取它的值。该映射在servlet init()方法中进行初始化,以保存许多数据库调用。如果sql表中的值发生了变化,我可以在不重新启动Servlet的情况下更新Map对象的值,因为init()方法只被调用一次。我可以为此做一个更新按钮吗?谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-09-15 13:06:51

是的,你应该可以。假设您的servlet类似于(减去异常)

代码语言:javascript
复制
public class MyServlet extends HttpServlet {
    private volatile Map<String, String> properties;
    private Object lock = new Object();

    public void init() {
        properties = ...; // from jdbc call
    }

    ...
}

您将在Map中拥有一个可以更改的properties引用。这里的危险之处在于,多个线程可能正在访问映射,因此如果您想要更改它,您需要使它成为volatile,以便所有Thread都可以看到更改,并且需要在锁上同步(或使用Lock对象),以便在进行更改时Thread等待,如果需要的话。

例如,您可能有一个执行updatePOST按钮。你的doPost()会像这样

代码语言:javascript
复制
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    Map<String, String> newProperties = ...; // get new map from jdbc call
    synchronized (lock) {
        properties = newProperties;
    }
}

就是这样。properties映射现在保存数据库中的新的最新属性(或任何其他属性)。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18807291

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档