170 похожих чатов

Уважаемые знатоки! Внимание, вопрос! Допустим, в каком-то потоке была создана

переменная типа умный указатель вот таким образом:
static thread_local std::shared_ptr<some_type> tls;
Затем, так получилось, что эта же переменная (shared_ptr, count() == 2) используется в другом потоке. Теперь, выполнение потока, в котором была создана переменная shared_ptr, завершено (count() == 1). Является ли неопределённым поведением использование этой переменной потоком, который её не создавал?

13 ответов

41 просмотр

ты не можешь использовать переменную tls в другом потоке, поскольку она создается на поток, а объект можешь, если сможешь его получить

Все валидно вроде

Ian-Mcewan Автор вопроса
Anatoly Shirokov
ты не можешь использовать переменную tls в другом ...

не могу сделать так? std::weak_ptr<type> global; void foo() { static thread_local std::shared_ptr<type> tls; if (!tls) { tls=std::make_shared<type>(); global=tls; } // use } void bar() { if (global) auto tmp=global.lock(); // use }

Ian-Mcewan Автор вопроса

валидно ли использование shared_ptr когда она пережила создавший её поток?

Ian Mcewan
валидно ли использование shared_ptr когда она пере...

самого шарадптра - нет, а вот контрольного блока и T - вполне

Ian-Mcewan Автор вопроса
Aleksander Spichak
самого шарадптра - нет, а вот контрольного блока и...

shared_ptr конечно не тот что в потоке ибо для доступа используется weak_ptr

Ian Mcewan
не могу сделать так? std::weak_ptr<type> global; ...

надо так проверку организовывать валидности объекта: if( auto p = global.lock() ) { // use p }

Ian-Mcewan Автор вопроса
Anatoly Shirokov
надо так проверку организовывать валидности объект...

Да, согласен. Интересовала допустимость концепта

Ian-Mcewan Автор вопроса
Ian Mcewan
Благодарю

только смотри, если кто-то напишет: std::shared_ptr<...> global2; ... if( auto p = global.lock() ) global2 = p; то твой shared будет валиден и после смерти потока. ну и еще пять копеек: shared_ptr тяжелый объект в плане сихронизации доступа. TLS же используют как раз для того чтобы уйти от примитивов синхронизации и т.п. поэтому вызывает вопрос вся идея с shared_ptr

Ian-Mcewan Автор вопроса
Anatoly Shirokov
только смотри, если кто-то напишет: std::shared_pt...

Написанного точно не будет. А вот shared_ptr как раз нужен из-за weak_ptr и того факта, что при завершении потока shared_ptr тоже уничтожится

Похожие вопросы

Обсуждают сегодня

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
2
Карта сайта