|
But so much allocate of memory is within a class already. There's nothing really gained by wrapping those things in a smart pointer. It's just more moving parts and syntax and generated code. The memory is already owned and managed by the object that allocated it, and of course deleting those things in the destructor allows you to catch any errors and log them for in the field diagnosis, which you can't do if you are just letting a destructing member delete the memory.
If you are passing allocated objects around, then of course it makes a lot more sense, but that's nothing new. It's been going on for a long time and isn't modern per se.
I certainly agree that stuff like override, member delete, member default, static_cast and such are significant improvements and they don't bring lots of baggage with them that you don't want, unlike a lot of other new stuff. Things like that, which improve type safety and the ability to express semantics are always a good thing in my opinion. I can't believe that we still don't have the option for explicit parameter direction indication.
Explorans limites defectum
|
|
|
|
|
I learned C++ the hard way. God, keep it hard- always. <evil-grin>
|
|
|
|
|
Why bother with that clumsy C++ at all?? People already invented "next C++" named "D". Wonderful language with a lot of features which C++ cannot dream of.
|
|
|
|
|
Let's compare these two equivalent code snippets:
C++:
auto start = std::chrono::high_resolution_clock::now();
doStuff();
auto stop = std::chrono::high_resolution_clock::now();
auto diff = stop - start;
auto ms = std::chrono::duration_cast<std::chrono::milliseconds>(diff);
std::cout << "Elapsed ms: " << ms.count() << " ms\n";
Python:
start = time.perf_counter()
do_stuff()
stop = time.perf_counter()
ms = (stop - start) * 1000.0
print('Elapsed ms: ', ms, ' ms')
In this case, the equivalent code is pretty similar, but modern C++ is generally more verbose out of the box.
|
|
|
|
|
And, to be fair, you only got it that small by giving up compile time safety though use of auto, which is one of the reasons you'd use C++ to begin with.
Explorans limites defectum
|
|
|
|
|
Auto deduces the type at compile time, so it's safe unless you intend the variable to be a base class of whatever the initializer returns.
|
|
|
|
|
But that's the problem, you didn't say explicitly what it should be. If the right side gets accidentally changed, nothing is going to complain if what it got changed to supports the same interface (not terribly uncommon in the modern world if lots and lots of operator driven stuff.)
If you explicitly say what it's supposed to be, then two things have to get simultaneous broken in the same way. If you don't, then only one has to get broken for potential silent errors.
Explorans limites defectum
|
|
|
|
|
If that was the case I wouldn't use auto . The situation you described is actually a feature of the auto keyword. It's pretty useful to only change the initializer without have to change the type declaration during refactoring.
|
|
|
|
|
I don't think the point of a language should to make it easy to refactor without having to really think about what you are doing and the potential silent errors it could introduce. Significant refactoring isn't common and it should be approached very carefully. Being explicit it always safer.
Explorans limites defectum
|
|
|
|
|
Dean Roddey wrote: Significant refactoring isn't common
I think you forgot the "joke" icon on your post.
|
|
|
|
|
If you are regularly doing large refactorings, then something is already badly wrong and you have bigger fish to fry, IMO. Maybe better safe than agile?
Explorans limites defectum
|
|
|
|
|
Removing old versions of the .NET Core SDKs. Well over a dozen different versions, including previews for 1.0, 1.1, 2.0, 2.1, 2.2, and 3.0 preview.
There is a list of the current SDK versions at Download .NET Core (Linux, macOS, and Windows).
A painful process as you need to uninstall each one individually.
"Time flies like an arrow. Fruit flies like a banana."
|
|
|
|
|
How many builds broke after that?
cheers
Chris Maunder
|
|
|
|
|
Oh oh, Matt's in trouble,
Chris came along and broke his bubble ...
Sent from my Amstrad PC 1640
Never throw anything away, Griff
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
AntiTwitter: @DalekDave is now a follower!
|
|
|
|
|
That bubble already broke. He fixed it though!
cheers
Chris Maunder
|
|
|
|
|
Damnit! Now I've got That Song[^] stuck in my head ... Earwormed myself.
Sent from my Amstrad PC 1640
Never throw anything away, Griff
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
AntiTwitter: @DalekDave is now a follower!
|
|
|
|
|
I remember trying to install Mathematica, which uses some library that is distributed with VC++, and there had been so many installs over the years that it just wouldn't work. I had to do a whole OS system wipe to get it to work.
|
|
|
|
|
Do depressed rabbits just not carrot all?
Sent from my Amstrad PC 1640
Never throw anything away, Griff
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
AntiTwitter: @DalekDave is now a follower!
|
|
|
|
|
Something doesn't add up - they still multiply.
/ravi
|
|
|
|
|
I think they just hop to it, buck up and get the job done.
"the debugger doesn't tell me anything because this code compiles just fine" - random QA comment
"Facebook is where you tell lies to your friends. Twitter is where you tell the truth to strangers." - chriselst
"I don't drink any more... then again, I don't drink any less." - Mike Mullikins uncle
|
|
|
|
|
|
Rajesh R Subramanian wrote: that's very bunny. Now that's hare raisingly funny!
/ravi
|
|
|
|
|
Hare we go again ...
Whenever you find yourself on the side of the majority, it is time to pause and reflect. - Mark Twain
|
|
|
|
|
I'm all ears
We can’t stop here, this is bat country - Hunter S Thompson RIP
|
|
|
|
|
Ear! Ear!
"If we don't change direction, we'll end up where we're going"
|
|
|
|