- Feature Articles
- CodeSOD
-
Error'd
- Most Recent Articles
- Secret Horror
- Not Impossible
- Monkeys
- Killing Time
- Hypersensitive
- Infallabella
- Doubled Daniel
- It Figures
- Forums
-
Other Articles
- Random Article
- Other Series
- Alex's Soapbox
- Announcements
- Best of…
- Best of Email
- Best of the Sidebar
- Bring Your Own Code
- Coded Smorgasbord
- Mandatory Fun Day
- Off Topic
- Representative Line
- News Roundup
- Editor's Soapbox
- Software on the Rocks
- Souvenir Potpourri
- Sponsor Post
- Tales from the Interview
- The Daily WTF: Live
- Virtudyne
Admin
:wtf:
<frist
Admin
Admin
What? It deduplicates memory and you only have to call malloc once, right?
Admin
I can't think of any. Though I have seen code like:
Admin
You can get into bad trouble with such trickery. It's how you discover that the platform you're running on has non-trivial alignment requirements. :smile:
Admin
Hang about… That code isn't even type-correct, so the compiler should be shitting bricks at this point. Also, it will be reading from memory that hasn't been written to, because the
[…]
operator in C does a dereference and the author didn't know aboutcalloc()
. Jesus Wept! This is awful.The only right thing to do with this code is to delete it. The only right thing to do with the code's author is to erase them.
Admin
Yeah, the only thing that for() loop does is write undefined values into the various
*_in
and*_out
buffers. Assuming those pointers are previously initialized, of course.Admin
Admin
"yeah ... the compiler gives lots of warnings when I compile this project, they're just annoying so I disabled them. I mean, it compiles okay and produces an object, we don't have time to waste chasing warnings around, we've got bugs to fix."
Admin
Sounds perfectly rasinable to me.
Admin
*cough* strict aliasing *cough*
Admin
Was exactly my thought when i read that....
If you are insane enough to make something like that, it makes perfect sense to you to just ignore those pesky warnings.
(This is why I always write code with the maximum warning verboseness the compiler/interpreter allows. That makes it less likely that any typos / wtfs on my part makes it past my testing and into production. Note that i say less likely, not impossible.. :-) )
Admin
This, I think, led some fine colleagues (at a previous workplace) to nominate themselves as GAU-8 targets by overlaying C++ objects (carefully crafted to permit a maximum of UB) over C-language declarations approximately equivalent (pun most definitely intended) to some grubby-looking Fortran
COMMON
blocks heavily dosed withEQUIVALENCE
.All in the name of creating a syntactic sugar class...
EDIT: left off a closing parenthesis...
Admin
Anyone who uses
reinterpret_cast
for anything else than casting from/tochar*
in cases where that's absolutely necessary deserves to be bludgeoned to death with a clue bat.Admin
Admin
:trollface:
Admin
(1) When I was much younger than I am now, I played Wasteland. I have carried some of its wording with me ever since.
Admin
Admin
http://www.thehaggis.com/EZ/sh/sh/imagelibrary/black-gold-stick-with-slices_350.jpg
Admin
To be fair, the standard doesn't have this "loophole"; it states (IIRC) that you're now allowed to access one object through the pointer of a different/incompatible type (exception:
char*
). So casting is OK, using the resulting pointer isn't.Admin
This was a technique which we used to good effect once to knit a c program with a FORTRAN program when we were under constraints we weren't particularly happy about being constrained by. While we appreciated the danger in what we were doing, we took great care to hide the business end in as hidden-away INCLUDE library module we could muster, and set severe constraints to the edit privileges. Damn thing worked like a dream.
Admin
Blood sausages a.k.a. black puddings, delightfully tasty and nourishing as they are, don't explode anywhere near as flamboyantly as haggises.
But then you have to catch them when they're young. The traditional technique of haggis-hunting espouses the use of a net, but recently the unscrupulous method of using vacuum-cleaners has started to become popular. Until Scotland becomes independent, unfortunately, the Scottish Parliament is powerless to enact any laws making it illegal to hunt haggis by vacuum.
Admin
Those of us who hunt the haggis with the use of a large electromagnet suspended from a drone are OK.
Admin
Please don't make me weep with despair.
Admin
That should do the same as
reinterpret_cast<void*>
, right? So no UB there…Admin
If the original pointer points to an element in a complicated inheritance tree, a
dynamic_cast<void *>
will give you a pointer to the outermost (most-derived) object without you having to know where you are in the tree and what the most-derived class actually is. It is more or less equivalent tostatic_cast<void *>(dynamic_cast<MostDerived *>(pointer))
.(Caveat: that was what it did on C++98. YMMV on C++11.)
Admin
Admin
Wow, TIL. Never needed that before…
Admin
Now, malloc is slow. I worked on a project that did lots of work with linked lists of equal-sized objects, and it was much faster to allocate by 10000*sizeof(list_elem_t) instead of doing malloc and free on each little list_elem_t.
But walking is slow too. I much prefer walking slow to being dragged behind a buggy buggy bugging speedily towards the edge of a precipice to plummet into a sea of buggy bugs.
Admin
Yeah, it's fairly obscure. I see two main uses for it:
Do two instances of AbstractBase refer to the same overall object? Sure, you can ask them, if they provide a method to do so, but it's a stricter test than an
operator ==
would provide. Just do the magic cast, and compare the results.Does this small object lie within that larger object accessed through a tiny base object? You need a class-specific
operator new
for the base class that enlarges the allocation by at least enough to be able to store the size of the object allocated, and then you can play stupid and marginally(1) portable pointer comparison games to see if the small thing lies in that range. I actually did this once, so that a refcounted object could try to provide a list of other refcounted objects that had member variables that were smart pointers to itself.(1) It's portable only if you use
std::less
to do the pointer comparisons, because that is guaranteed to compare pointers in whatever funky architecture-specific way is necessary.Admin
Admin
Well, obviously. If you need performance, you should make sure you don't (de-)allocate memory all the time. You also need to be able to control the location of your objects in memory.
Yeah, I remember that. Don't ask me why I needed to sort objects by their location in memory some time ago…
Admin
That's true, and the cost comes from three things:
Per-thread arenas are much cheaper if you can construct them and avoid having to go to the locking stage. But you're still going to have locality of reference issues; you're getting a new space to write into, so it is bound to have to evict something else (since the likelihood that the cache is empty is vanishingly small on any real system running real programs).
None of which should stop you from using
malloc()
(ornew
in C++, which is a fancy wrapper roundmalloc()
) if you need it. Sometimes people lose sight of that.Admin
malloc (or new) is only really "bad" when people get lazy. Don't run a hot loop, creating a new int inside each iteration. As much as I enjoy coding in .NET and C#, I think .NET has done too good of a job, for people just getting into software development, of hiding what's really going on in the background. I've met too many junior dev's with zero concept of memory allocation/management. Even with a memory managed framework, you should understand heaps and pointers and "help" the GC know when to dispose stuff.
Just because your gun has the safety on, doesn't mean you should run through the mall pulling the trigger.
Managed frameworks as supposed to help prevent accidental memory leaks, not be a crutch to not ever learning how memory management works.
Admin
From my experience trying to "help" the GC 99.9% of the time is a huge WTF.
... I do agree with your general point, which is that it never hurts to be aware of how much memory you're actually using at any given moment.
Admin
I will agree with you, but only to the extent that (in my experience) it's because developers who don't understand memory allocation and try to "help" the GC the wrong way. Usually, by "forcing" garbage collection, thinking that it will just magically keep the application's memory footprint small.
It's shocking to me how many developers I've worked with (usually fresh out of school, sometimes even with a "Masters" degree) who have no clue what the difference is between "heap" and "stack" or "class" and "struct". I get that they don't generally teach specific languages in school, but you would expect them to at least touch on basic concepts like memory allocation and error handling.
Admin
:wtf::question: I learned that, and I wasn't even a CS major.
Admin
Many colleges have bad CS programs. I've experienced it first hand and have seen the effects of it on various forums.
Admin
That's because as soon as you use GC and a virtual machine, you pretty much give up control over memory (de-)allocations and controlling the memory location of your data structures. Which is a good thing if you just want to quickly get stuff done, but will be a huge pain in the ass if you need to optimize for performance.
There's a reason
sun.misc.Unsafe
is so popular.Admin
IME that can be a bad curriculum, a bad school, or a bad student who managed to muddle through a school good enough that the student should have learnt things but not good enough to keep the bad students from getting the diploma. Or the guy may not have the degree at all, of course.
Admin
And some are not bad, but focus very much on the theoretical to the severe detriment of the practical. I don't know if it's true, but I remember being told once that it was possible to get a CS degree from Berkeley without ever writing an actual program.
Admin
Don't rely on the diploma to short-cut the interviewing process. The school's criteria for passing the student are not your criteria for hiring them. And I say this despite working at a university; some graduates are just horribly wet behind the ears and need a few years of life to knock some sense in before they're worth putting on the payroll.
Admin
Since interview coding questions are apparently ill-seen by HR, my solution for hiring fresh-out-of-school talent is to take not-yet-graduated students as interns (in France most or all five-year engineering degrees mandate several months of internship). If the guy is good, hire him (or her, obviously). Who could have been certain on the basis of a mere job interview that the gal with a master's in biology who - not finding work - did a one-year class in computing would be a natural at Pig queries?) This is even more important in France than in the US, because after hiring someone you get three months to say "sorry you don't fit after all", after that you're basically stuck with the guy unless he does something really wrong. On my side-line as TA for master's students, I can only wonder at how some students got there and what they are going to be able to do once they get their diploma...
Admin
Most places I've worked have a general policy that the initial period of employment (usually the first three months or so) is probationary. In fact scrub that, make that all the places I've worked. Then you both get the opportunity to try each other out to see whether you are as good a fit as you anticipated from the interview process. This proby period has proved extremely useful to both parties on two specific occasions where I started a period of employment that both I and the employer had second thoughts about.
Admin
You ever heard of a C union?
Admin
Does it involve a C civil ceremony?
Admin
And is it followed by a C reception?
Admin
Will the reception have C food?
Admin
No, that's UB.
Admin