Is there a way to make member function NOT callable from constructor?What are the differences between a pointer variable and a reference variable in C++?Virtual member call in a constructorHow do I call one constructor from another in Java?Can I call a constructor from another constructor (do constructor chaining) in C++?What is a clean, pythonic way to have multiple constructors in Python?Throwing exceptions from constructorsCall one constructor from anotherEquality-compare std::weak_ptrClass inheritance: Constructor and member functions of class not recognized by compilerIs it bad practice to have a constructor function return a Promise?
What are the spoon bit of a spoon and fork bit of a fork called?
Do I have an "anti-research" personality?
Pulling the rope with one hand is as heavy as with two hands?
Binary Numbers Magic Trick
Historically, were women trained for obligatory wars? Or did they serve some other military function?
Has any spacecraft ever had the ability to directly communicate with civilian air traffic control?
Help, my Death Star suffers from Kessler syndrome!
What is the strongest case that can be made in favour of the UK regaining some control over fishing policy after Brexit?
What word means to make something obsolete?
What is a Recurrent Neural Network?
What's the metal clinking sound at the end of credits in Avengers: Endgame?
"ne paelici suspectaretur" (Tacitus)
Morally unwholesome deeds knowing the consequences but without unwholesome intentions
Why does the Betti number give the measure of k-dimensional holes?
Build a trail cart
Given what happens in Endgame, why doesn't Dormammu come back to attack the universe?
Python "triplet" dictionary?
Is thermodynamics only applicable to systems in equilibrium?
Examples of non trivial equivalence relations , I mean equivalence relations without the expression " same ... as" in their definition?
Multiple options for Pseudonyms
Why do Ichisongas hate elephants and hippos?
What is the difference between `a[bc]d` (brackets) and `ab,cd` (braces)?
Reverse the word in a string with the same order in javascript
Why was Germany not as successful as other Europeans in establishing overseas colonies?
Is there a way to make member function NOT callable from constructor?
What are the differences between a pointer variable and a reference variable in C++?Virtual member call in a constructorHow do I call one constructor from another in Java?Can I call a constructor from another constructor (do constructor chaining) in C++?What is a clean, pythonic way to have multiple constructors in Python?Throwing exceptions from constructorsCall one constructor from anotherEquality-compare std::weak_ptrClass inheritance: Constructor and member functions of class not recognized by compilerIs it bad practice to have a constructor function return a Promise?
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty height:90px;width:728px;box-sizing:border-box;
I have member function (method) which uses
std::enable_shared_from_this::weak_from_this()
In short: weak_from_this
returns weak_ptr
to this. One caveat is it can't be used from constructor.
If somebody would use my function from constructor of inherited class, weak_from_this
inside it would return expired weak_ptr
. I guard against that with assertion checking that it's not expired, but it's a run-time check.
Is there a way to check against it at compile time?
c++ constructor c++17 shared-ptr weak-ptr
add a comment |
I have member function (method) which uses
std::enable_shared_from_this::weak_from_this()
In short: weak_from_this
returns weak_ptr
to this. One caveat is it can't be used from constructor.
If somebody would use my function from constructor of inherited class, weak_from_this
inside it would return expired weak_ptr
. I guard against that with assertion checking that it's not expired, but it's a run-time check.
Is there a way to check against it at compile time?
c++ constructor c++17 shared-ptr weak-ptr
Note there is a difference in scope between a child class constructor body and the parent class constructor: the latter has been executed completely before you even start initializing the child class's members (if any), let alone enter the child class constructor body.
– rubenvb
Apr 8 at 14:58
4
Nice question. One way would be to make a dummy class with pure virtual functionweak_from_this
and inherit yours from it. This will make it a hard compile error.
– SergeyA
Apr 8 at 14:59
5
@SergeyA Why didn't you post that as an answer? All other people here seem to conclude that it's not possible so either your comment is wrong and misleading or they are wrong and you should show how it can be achieved.
– Bakuriu
Apr 8 at 21:17
@Bakuriu well, I did not have the energy to polish it to the full blown answer. It is possible that it is not a workable solution.
– SergeyA
Apr 9 at 14:07
Simply based on the fact the static type of an object doesn't (and cannot) depend on the fact its construction is completed. Note that if that were the case, you wouldn't be able in a ctor ofT
to storethis
in a global obj register, and use the obj later, w/o a cast, as the ptr stored would have "(in construction)T*" not plainT*
.
– curiousguy
Apr 14 at 12:27
add a comment |
I have member function (method) which uses
std::enable_shared_from_this::weak_from_this()
In short: weak_from_this
returns weak_ptr
to this. One caveat is it can't be used from constructor.
If somebody would use my function from constructor of inherited class, weak_from_this
inside it would return expired weak_ptr
. I guard against that with assertion checking that it's not expired, but it's a run-time check.
Is there a way to check against it at compile time?
c++ constructor c++17 shared-ptr weak-ptr
I have member function (method) which uses
std::enable_shared_from_this::weak_from_this()
In short: weak_from_this
returns weak_ptr
to this. One caveat is it can't be used from constructor.
If somebody would use my function from constructor of inherited class, weak_from_this
inside it would return expired weak_ptr
. I guard against that with assertion checking that it's not expired, but it's a run-time check.
Is there a way to check against it at compile time?
c++ constructor c++17 shared-ptr weak-ptr
c++ constructor c++17 shared-ptr weak-ptr
edited Apr 14 at 12:27
curiousguy
4,69223046
4,69223046
asked Apr 8 at 14:53
KorriKorri
38629
38629
Note there is a difference in scope between a child class constructor body and the parent class constructor: the latter has been executed completely before you even start initializing the child class's members (if any), let alone enter the child class constructor body.
– rubenvb
Apr 8 at 14:58
4
Nice question. One way would be to make a dummy class with pure virtual functionweak_from_this
and inherit yours from it. This will make it a hard compile error.
– SergeyA
Apr 8 at 14:59
5
@SergeyA Why didn't you post that as an answer? All other people here seem to conclude that it's not possible so either your comment is wrong and misleading or they are wrong and you should show how it can be achieved.
– Bakuriu
Apr 8 at 21:17
@Bakuriu well, I did not have the energy to polish it to the full blown answer. It is possible that it is not a workable solution.
– SergeyA
Apr 9 at 14:07
Simply based on the fact the static type of an object doesn't (and cannot) depend on the fact its construction is completed. Note that if that were the case, you wouldn't be able in a ctor ofT
to storethis
in a global obj register, and use the obj later, w/o a cast, as the ptr stored would have "(in construction)T*" not plainT*
.
– curiousguy
Apr 14 at 12:27
add a comment |
Note there is a difference in scope between a child class constructor body and the parent class constructor: the latter has been executed completely before you even start initializing the child class's members (if any), let alone enter the child class constructor body.
– rubenvb
Apr 8 at 14:58
4
Nice question. One way would be to make a dummy class with pure virtual functionweak_from_this
and inherit yours from it. This will make it a hard compile error.
– SergeyA
Apr 8 at 14:59
5
@SergeyA Why didn't you post that as an answer? All other people here seem to conclude that it's not possible so either your comment is wrong and misleading or they are wrong and you should show how it can be achieved.
– Bakuriu
Apr 8 at 21:17
@Bakuriu well, I did not have the energy to polish it to the full blown answer. It is possible that it is not a workable solution.
– SergeyA
Apr 9 at 14:07
Simply based on the fact the static type of an object doesn't (and cannot) depend on the fact its construction is completed. Note that if that were the case, you wouldn't be able in a ctor ofT
to storethis
in a global obj register, and use the obj later, w/o a cast, as the ptr stored would have "(in construction)T*" not plainT*
.
– curiousguy
Apr 14 at 12:27
Note there is a difference in scope between a child class constructor body and the parent class constructor: the latter has been executed completely before you even start initializing the child class's members (if any), let alone enter the child class constructor body.
– rubenvb
Apr 8 at 14:58
Note there is a difference in scope between a child class constructor body and the parent class constructor: the latter has been executed completely before you even start initializing the child class's members (if any), let alone enter the child class constructor body.
– rubenvb
Apr 8 at 14:58
4
4
Nice question. One way would be to make a dummy class with pure virtual function
weak_from_this
and inherit yours from it. This will make it a hard compile error.– SergeyA
Apr 8 at 14:59
Nice question. One way would be to make a dummy class with pure virtual function
weak_from_this
and inherit yours from it. This will make it a hard compile error.– SergeyA
Apr 8 at 14:59
5
5
@SergeyA Why didn't you post that as an answer? All other people here seem to conclude that it's not possible so either your comment is wrong and misleading or they are wrong and you should show how it can be achieved.
– Bakuriu
Apr 8 at 21:17
@SergeyA Why didn't you post that as an answer? All other people here seem to conclude that it's not possible so either your comment is wrong and misleading or they are wrong and you should show how it can be achieved.
– Bakuriu
Apr 8 at 21:17
@Bakuriu well, I did not have the energy to polish it to the full blown answer. It is possible that it is not a workable solution.
– SergeyA
Apr 9 at 14:07
@Bakuriu well, I did not have the energy to polish it to the full blown answer. It is possible that it is not a workable solution.
– SergeyA
Apr 9 at 14:07
Simply based on the fact the static type of an object doesn't (and cannot) depend on the fact its construction is completed. Note that if that were the case, you wouldn't be able in a ctor of
T
to store this
in a global obj register, and use the obj later, w/o a cast, as the ptr stored would have "(in construction)T*" not plain T*
.– curiousguy
Apr 14 at 12:27
Simply based on the fact the static type of an object doesn't (and cannot) depend on the fact its construction is completed. Note that if that were the case, you wouldn't be able in a ctor of
T
to store this
in a global obj register, and use the obj later, w/o a cast, as the ptr stored would have "(in construction)T*" not plain T*
.– curiousguy
Apr 14 at 12:27
add a comment |
3 Answers
3
active
oldest
votes
I am afraid the answer is "no, it's not possible to protect against this at compile-time." It's always difficult to prove a negative, but consider this: if it was possible to protect a function this way, it would probably have been done for weak_from_this
and shared_from_this
in the standard library itself.
add a comment |
No there is no way. Consider:
void call_me(struct widget*);
struct widget : std::enable_shared_from_this<widget>
widget()
call_me(this);
void display()
shared_from_this();
;
// later:
void call_me(widget* w)
w->display(); // crash
The thing is there is a reason you want to check for not calling shared_from_this
in the constructor. Think about that reason. It's not that shared_from_this
cannot be called, it's because it's return value has no way of being assigned yet. It is also not because it will never be assigned. It's because it will be assigned later in the execution of the code. Order of operation is a runtime property of your program. You cannot assert at compile time for order of operation, which is done at runtime.
add a comment |
Not as such, but - if performance is not an issue, you could add a flag which indicates construction is complete, and use that to fail at run-time with such calls:
class A
// ... whatever ...
public:
A()
// do construction work
constructed = true;
foo()
if (not constructed)
throw std::logic_error("Cannot call foo() during construction");
// the rest of foo
protected:
bool constructed false ;
You could also make these checks only apply when compiling in DEBUG mode (e.g. with conditional compilation using the preprocessor - #ifndef NDEBUG
) so that at run time you won't get the performance penalty. Mind the noexcept
s though.
An alternative to throwing could be assert()
'ing.
Since apparently there isn't compile-time solution which doesn't make code less readable, I decided to go withassert(!wptr.expired())
. I think it's a little bit more fitting than exception, because there is no way to recover from this situation.
– Korri
Apr 8 at 17:23
@Korri remember thatassert
s are usually compiled out in release builds, so nothing will happen. An exception however is not, so it would still terminate the program (if not caught and swallowed) in a release build. You could do both; firstassert
thenthrow
, or justthrow
.
– Jesper Juhl
Apr 8 at 18:38
add a comment |
Your Answer
StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55576192%2fis-there-a-way-to-make-member-function-not-callable-from-constructor%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
3 Answers
3
active
oldest
votes
3 Answers
3
active
oldest
votes
active
oldest
votes
active
oldest
votes
I am afraid the answer is "no, it's not possible to protect against this at compile-time." It's always difficult to prove a negative, but consider this: if it was possible to protect a function this way, it would probably have been done for weak_from_this
and shared_from_this
in the standard library itself.
add a comment |
I am afraid the answer is "no, it's not possible to protect against this at compile-time." It's always difficult to prove a negative, but consider this: if it was possible to protect a function this way, it would probably have been done for weak_from_this
and shared_from_this
in the standard library itself.
add a comment |
I am afraid the answer is "no, it's not possible to protect against this at compile-time." It's always difficult to prove a negative, but consider this: if it was possible to protect a function this way, it would probably have been done for weak_from_this
and shared_from_this
in the standard library itself.
I am afraid the answer is "no, it's not possible to protect against this at compile-time." It's always difficult to prove a negative, but consider this: if it was possible to protect a function this way, it would probably have been done for weak_from_this
and shared_from_this
in the standard library itself.
answered Apr 8 at 14:59
AngewAngew
135k11261357
135k11261357
add a comment |
add a comment |
No there is no way. Consider:
void call_me(struct widget*);
struct widget : std::enable_shared_from_this<widget>
widget()
call_me(this);
void display()
shared_from_this();
;
// later:
void call_me(widget* w)
w->display(); // crash
The thing is there is a reason you want to check for not calling shared_from_this
in the constructor. Think about that reason. It's not that shared_from_this
cannot be called, it's because it's return value has no way of being assigned yet. It is also not because it will never be assigned. It's because it will be assigned later in the execution of the code. Order of operation is a runtime property of your program. You cannot assert at compile time for order of operation, which is done at runtime.
add a comment |
No there is no way. Consider:
void call_me(struct widget*);
struct widget : std::enable_shared_from_this<widget>
widget()
call_me(this);
void display()
shared_from_this();
;
// later:
void call_me(widget* w)
w->display(); // crash
The thing is there is a reason you want to check for not calling shared_from_this
in the constructor. Think about that reason. It's not that shared_from_this
cannot be called, it's because it's return value has no way of being assigned yet. It is also not because it will never be assigned. It's because it will be assigned later in the execution of the code. Order of operation is a runtime property of your program. You cannot assert at compile time for order of operation, which is done at runtime.
add a comment |
No there is no way. Consider:
void call_me(struct widget*);
struct widget : std::enable_shared_from_this<widget>
widget()
call_me(this);
void display()
shared_from_this();
;
// later:
void call_me(widget* w)
w->display(); // crash
The thing is there is a reason you want to check for not calling shared_from_this
in the constructor. Think about that reason. It's not that shared_from_this
cannot be called, it's because it's return value has no way of being assigned yet. It is also not because it will never be assigned. It's because it will be assigned later in the execution of the code. Order of operation is a runtime property of your program. You cannot assert at compile time for order of operation, which is done at runtime.
No there is no way. Consider:
void call_me(struct widget*);
struct widget : std::enable_shared_from_this<widget>
widget()
call_me(this);
void display()
shared_from_this();
;
// later:
void call_me(widget* w)
w->display(); // crash
The thing is there is a reason you want to check for not calling shared_from_this
in the constructor. Think about that reason. It's not that shared_from_this
cannot be called, it's because it's return value has no way of being assigned yet. It is also not because it will never be assigned. It's because it will be assigned later in the execution of the code. Order of operation is a runtime property of your program. You cannot assert at compile time for order of operation, which is done at runtime.
answered Apr 8 at 15:37
Guillaume RacicotGuillaume Racicot
16.7k53873
16.7k53873
add a comment |
add a comment |
Not as such, but - if performance is not an issue, you could add a flag which indicates construction is complete, and use that to fail at run-time with such calls:
class A
// ... whatever ...
public:
A()
// do construction work
constructed = true;
foo()
if (not constructed)
throw std::logic_error("Cannot call foo() during construction");
// the rest of foo
protected:
bool constructed false ;
You could also make these checks only apply when compiling in DEBUG mode (e.g. with conditional compilation using the preprocessor - #ifndef NDEBUG
) so that at run time you won't get the performance penalty. Mind the noexcept
s though.
An alternative to throwing could be assert()
'ing.
Since apparently there isn't compile-time solution which doesn't make code less readable, I decided to go withassert(!wptr.expired())
. I think it's a little bit more fitting than exception, because there is no way to recover from this situation.
– Korri
Apr 8 at 17:23
@Korri remember thatassert
s are usually compiled out in release builds, so nothing will happen. An exception however is not, so it would still terminate the program (if not caught and swallowed) in a release build. You could do both; firstassert
thenthrow
, or justthrow
.
– Jesper Juhl
Apr 8 at 18:38
add a comment |
Not as such, but - if performance is not an issue, you could add a flag which indicates construction is complete, and use that to fail at run-time with such calls:
class A
// ... whatever ...
public:
A()
// do construction work
constructed = true;
foo()
if (not constructed)
throw std::logic_error("Cannot call foo() during construction");
// the rest of foo
protected:
bool constructed false ;
You could also make these checks only apply when compiling in DEBUG mode (e.g. with conditional compilation using the preprocessor - #ifndef NDEBUG
) so that at run time you won't get the performance penalty. Mind the noexcept
s though.
An alternative to throwing could be assert()
'ing.
Since apparently there isn't compile-time solution which doesn't make code less readable, I decided to go withassert(!wptr.expired())
. I think it's a little bit more fitting than exception, because there is no way to recover from this situation.
– Korri
Apr 8 at 17:23
@Korri remember thatassert
s are usually compiled out in release builds, so nothing will happen. An exception however is not, so it would still terminate the program (if not caught and swallowed) in a release build. You could do both; firstassert
thenthrow
, or justthrow
.
– Jesper Juhl
Apr 8 at 18:38
add a comment |
Not as such, but - if performance is not an issue, you could add a flag which indicates construction is complete, and use that to fail at run-time with such calls:
class A
// ... whatever ...
public:
A()
// do construction work
constructed = true;
foo()
if (not constructed)
throw std::logic_error("Cannot call foo() during construction");
// the rest of foo
protected:
bool constructed false ;
You could also make these checks only apply when compiling in DEBUG mode (e.g. with conditional compilation using the preprocessor - #ifndef NDEBUG
) so that at run time you won't get the performance penalty. Mind the noexcept
s though.
An alternative to throwing could be assert()
'ing.
Not as such, but - if performance is not an issue, you could add a flag which indicates construction is complete, and use that to fail at run-time with such calls:
class A
// ... whatever ...
public:
A()
// do construction work
constructed = true;
foo()
if (not constructed)
throw std::logic_error("Cannot call foo() during construction");
// the rest of foo
protected:
bool constructed false ;
You could also make these checks only apply when compiling in DEBUG mode (e.g. with conditional compilation using the preprocessor - #ifndef NDEBUG
) so that at run time you won't get the performance penalty. Mind the noexcept
s though.
An alternative to throwing could be assert()
'ing.
edited Apr 9 at 7:29
answered Apr 8 at 16:58
einpoklumeinpoklum
38.2k28135266
38.2k28135266
Since apparently there isn't compile-time solution which doesn't make code less readable, I decided to go withassert(!wptr.expired())
. I think it's a little bit more fitting than exception, because there is no way to recover from this situation.
– Korri
Apr 8 at 17:23
@Korri remember thatassert
s are usually compiled out in release builds, so nothing will happen. An exception however is not, so it would still terminate the program (if not caught and swallowed) in a release build. You could do both; firstassert
thenthrow
, or justthrow
.
– Jesper Juhl
Apr 8 at 18:38
add a comment |
Since apparently there isn't compile-time solution which doesn't make code less readable, I decided to go withassert(!wptr.expired())
. I think it's a little bit more fitting than exception, because there is no way to recover from this situation.
– Korri
Apr 8 at 17:23
@Korri remember thatassert
s are usually compiled out in release builds, so nothing will happen. An exception however is not, so it would still terminate the program (if not caught and swallowed) in a release build. You could do both; firstassert
thenthrow
, or justthrow
.
– Jesper Juhl
Apr 8 at 18:38
Since apparently there isn't compile-time solution which doesn't make code less readable, I decided to go with
assert(!wptr.expired())
. I think it's a little bit more fitting than exception, because there is no way to recover from this situation.– Korri
Apr 8 at 17:23
Since apparently there isn't compile-time solution which doesn't make code less readable, I decided to go with
assert(!wptr.expired())
. I think it's a little bit more fitting than exception, because there is no way to recover from this situation.– Korri
Apr 8 at 17:23
@Korri remember that
assert
s are usually compiled out in release builds, so nothing will happen. An exception however is not, so it would still terminate the program (if not caught and swallowed) in a release build. You could do both; first assert
then throw
, or just throw
.– Jesper Juhl
Apr 8 at 18:38
@Korri remember that
assert
s are usually compiled out in release builds, so nothing will happen. An exception however is not, so it would still terminate the program (if not caught and swallowed) in a release build. You could do both; first assert
then throw
, or just throw
.– Jesper Juhl
Apr 8 at 18:38
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55576192%2fis-there-a-way-to-make-member-function-not-callable-from-constructor%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Note there is a difference in scope between a child class constructor body and the parent class constructor: the latter has been executed completely before you even start initializing the child class's members (if any), let alone enter the child class constructor body.
– rubenvb
Apr 8 at 14:58
4
Nice question. One way would be to make a dummy class with pure virtual function
weak_from_this
and inherit yours from it. This will make it a hard compile error.– SergeyA
Apr 8 at 14:59
5
@SergeyA Why didn't you post that as an answer? All other people here seem to conclude that it's not possible so either your comment is wrong and misleading or they are wrong and you should show how it can be achieved.
– Bakuriu
Apr 8 at 21:17
@Bakuriu well, I did not have the energy to polish it to the full blown answer. It is possible that it is not a workable solution.
– SergeyA
Apr 9 at 14:07
Simply based on the fact the static type of an object doesn't (and cannot) depend on the fact its construction is completed. Note that if that were the case, you wouldn't be able in a ctor of
T
to storethis
in a global obj register, and use the obj later, w/o a cast, as the ptr stored would have "(in construction)T*" not plainT*
.– curiousguy
Apr 14 at 12:27