Я пытаюсь использовать ThreadLocal
, чтобы обеспечить безопасность потоков до уже существующих классов, не связанных с потоком, но испытывающих проблемы. Похоже, что не выполняется изоляция - что потоки по-прежнему разделяют статичность, а не локальны для каждого потока.Использование ThreadLocal с существующими классами, которые содержат статические члены
Я считаю, что мое использование почти точно совпадает с примером локализации SimpleDateFormatter
, описанным в this StackOverflow question, но это не работает так, как я надеюсь.
Я надеюсь, что кто-то из тех, кто использовал это, укажет на грубую ошибку, которую я должен сделать ... поэтому, я думаю, мой вопрос: можете ли вы определить, что я делаю неправильно здесь?
Вот мой простой класс:
public class SimpleClassWithStaticMembers {
private static String theStaticString =
"StaticStringInClassWithStaticMember";
public void setTheStaticString (String val) {
SimpleClassWithStaticMembers.theStaticString = val;
}
public String getTheStaticString() {
return SimpleClassWithStaticMembers.theStaticString;
}
}
И это класс нить, которая создает ThreadLocal экземпляры SimpleClassWithStaticMembers
:
public class SimpleTesterThread extends Thread {
private void showMsg (String msg) {
System.out.println (msg);
System.out.flush();
}
public SimpleTesterThread (String threadId) {
super(threadId);
}
public void run() {
try { Thread.sleep(2000); } catch (InterruptedException ex) { }
ThreadLocal<SimpleClassWithStaticMembers> localizedClass =
new ThreadLocal<SimpleClassWithStaticMembers>();
localizedClass.set(new SimpleClassWithStaticMembers());
// repeating here to be sure we overlap all with all
for (int ii=0; ii < 3; ii++) {
localizedClass.get().setTheStaticString ("Setby_" + this.getName());
try { Thread.sleep(2000); } catch (InterruptedException ex) { }
showMsg(" Thread [" + this.getName() + "] - "
+ localizedClass.get().getTheStaticString() + "'.");
}
showMsg ("Thread [" + this.getName()
+ "] complete. Our 'threadlocal' string is now - "
+ localizedClass.get().getTheStaticString() + "'.");
localizedClass.remove();
}
}
Когда десять экземпляров SimpleTesterThread
созданы (давая им различные имена потоков, как «AAAAAAAAAA», «BBBBBBBBB» и т. Д.), А затем началось, вывод ясно показывает, что они совместно используют экземпляры. Вход Выход включает в себя:
... Thread [JJJJJJJJJJ] - Setby_CCCCCCCCCC'. Thread [DDDDDDDDDD] - Setby_JJJJJJJJJJ'. Thread [IIIIIIIIII] - Setby_DDDDDDDDDD'. Thread [GGGGGGGGGG] - Setby_IIIIIIIIII'. Thread [EEEEEEEEEE] - Setby_GGGGGGGGGG'. Thread [EEEEEEEEEE] complete. Our 'threadlocal' string is now - Setby_GGGGGGGGGG'. Thread [HHHHHHHHHH] - Setby_GGGGGGGGGG'. Thread [BBBBBBBBBB] - Setby_GGGGGGGGGG'. Thread [FFFFFFFFFF] - Setby_GGGGGGGGGG'. Thread [FFFFFFFFFF] complete. Our 'threadlocal' string is now - Setby_GGGGGGGGGG'. ... Thread [JJJJJJJJJJ] - Setby_GGGGGGGGGG'. Thread [JJJJJJJJJJ] complete. Our 'threadlocal' string is now - Setby_GGGGGGGGGG'. Thread [HHHHHHHHHH] complete. Our 'threadlocal' string is now - Setby_GGGGGGGGGG'. Thread [GGGGGGGGGG] - Setby_GGGGGGGGGG'. Thread [GGGGGGGGGG] complete. Our 'threadlocal' string is now - Setby_GGGGGGGGGG'. Thread [IIIIIIIIII] - Setby_GGGGGGGGGG'. Thread [CCCCCCCCCC] - Setby_GGGGGGGGGG'. Thread [CCCCCCCCCC] complete. Our 'threadlocal' string is now - Setby_GGGGGGGGGG'. Thread [AAAAAAAAAA] complete. Our 'threadlocal' string is now - Setby_GGGGGGGGGG'. Thread [DDDDDDDDDD] - Setby_GGGGGGGGGG'. Thread [DDDDDDDDDD] complete. Our 'threadlocal' string is now - Setby_GGGGGGGGGG'. Thread [IIIIIIIIII] complete. Our 'threadlocal' string is now - Setby_GGGGGGGGGG'. ============== all threads complete.
Я не включил класс, который создает, начинается, и соединяет нити - если это чувствовал, чтобы быть полезным, я с удовольствием редактировать, чтобы добавить его.
Интересно, возникает ли проблема, что вы «начинаете» потоки, вызывая метод 'run()' вместо метода 'start()' ... –
Спасибо за предложение, Стивен.Потоки запускаются с помощью метода start(), но это, безусловно, может иметь эффект. – CPerkins