|
Lucky you! If that gauge went to insanely high values, your eyes must have been bleeding by now.
"The worst code you'll come across is code you wrote last year.", wizardzz[ ^]
|
|
|
|
|
Yeah, if a boss measures programmer’s value by the number of lines they produce then they will get a lot of verbose code. OTOH, I think this guy just didn’t know how to do the task efficiently.
Just because the code works, it doesn't mean that it is good code.
|
|
|
|
|
CIDev wrote: Yeah, if a boss measures programmer’s value by the number of lines they produce then they will get a lot of verbose code
Oh, you mean, elegant, concise code, along the lines of (Java code):
breadcrumbs.setText((breadcrumbs.getText().equals("")) ? pressedItem : breadcrumbs.getText() + " -> " + pressedItem);
will actually get me less money?
Screw that, i'll just go with
StringBuilder builder = new StringBuilder();
if(breadcrumbs.getText().equals("")) {
builder.append(pressedItem);
} else {
builder.append(breadcrumbs.getText());
builder.append("->");
builder.append(pressedItem);
}
breadcrumbs.setText(builder.toString());
Screw simplicity, that should get me 9 times more money
And yes, I'm a fan of ternaries
And now, seriously, we should come up with a measurement tool for efficiency / readability, and not lines of code.
Full-fledged Java/.NET lover, full-fledged PHP hater.
Full-fledged Google/Microsoft lover, full-fledged Apple hater.
Full-fledged Skype lover, full-fledged YM hater.
|
|
|
|
|
Andrei Straut wrote: And yes, I'm a fan of ternaries
Brother!
|
|
|
|
|
Hey, bros, I like ternaries too.
Just because the code works, it doesn't mean that it is good code.
|
|
|
|
|
CIDev wrote: Hey, bros, I like ternaries too.
We should make a club. "The Ternary Project" sounds just about right
Full-fledged Java/.NET lover, full-fledged PHP hater.
Full-fledged Google/Microsoft lover, full-fledged Apple hater.
Full-fledged Skype lover, full-fledged YM hater.
|
|
|
|
|
Andrei Straut wrote: We should make a club. "The Ternary Project" sounds just about right
Sounds good, especially since there are 3 of us.
Just because the code works, it doesn't mean that it is good code.
|
|
|
|
|
CIDev wrote: Sounds good, especially since there are 3 of us.
Look, we even have a website now. It's just perfect!
Full-fledged Java/.NET lover, full-fledged PHP hater.
Full-fledged Google/Microsoft lover, full-fledged Apple hater.
Full-fledged Skype lover, full-fledged YM hater.
|
|
|
|
|
|
What do you mean? It's working just as it should!
Full-fledged Java/.NET lover, full-fledged PHP hater.
Full-fledged Google/Microsoft lover, full-fledged Apple hater.
Full-fledged Skype lover, full-fledged YM hater.
|
|
|
|
|
Just because the code works, it doesn't mean that it is good code.
|
|
|
|
|
|
Measuring "productivity" by lines of code written per unit time is bad, but I know of a case that's worse: measuring it by the number of faults found and fixed per unit time.
I was assigned to a project about twenty years ago that actually used such a metric. The top guy thought it was a clever twist on SLOC metrics. He reasoned that what really matters is whether the program meets its specification and is working properly -- so far, so good -- so lines-of-code-written is an irrelevant metric. But bug fixing, which is, after all, the process by which a faulty program approaches acceptability, struck him as just right!
I'd never before seen software engineers deliberately write huge numbers of bugs into their code. Pray God, I never see it again.
(This message is programming you in ways you cannot detect. Be afraid.)
|
|
|
|
|
Yeah, you get what you reward for, but rewarding for bug fixes is really bad.
Just because the code works, it doesn't mean that it is good code.
|
|
|
|
|
It would be okay if either the development was done in the past (so not influenced by the reward), or you only got a reward if the bug you fixed wasn't introduced by your team. But yeah otherwise that is a really stupid thing to measure.
I know it's really vague but basing rewards on customer satisfaction is really the way to go. Basing it on any particular code-related metric will just result in developers working to that metric and ignoring the actual end product.
|
|
|
|
|
A friend of mine used to work at a place that had a similar situation. The powers that be had decided to tie the group's bonus structure to the number of cases/bugs that were closed. So what did that encourage? Of course, all the project managers were closing bugs left, right, and center (fixed or not), and QA would just open a brand new one ... pretty much a copy/paste of the old.
It was a great team building exercise that everybody could get excited about.
|
|
|
|
|
My choice: payment per hour + a realistic manhour estimation + a boss who plays fair and understands that things change + trusted, honest employees + a pizza-day at least once a week.
Greetings - Jacek
|
|
|
|
|
I would not be surprised if this code actually ran faster than most other schemes. But, for a battery gauge?
|
|
|
|
|
While debugging a legacy stored proc from one of our systems, I've come across this:
CREATE PROCEDURE p_create_po_serial (
IN param_reception_ids VARCHAR(255),
IN param_serial_nos VARCHAR(1023),
OUT serial_no_ids VARCHAR(1023))
BEGIN
DECLARE id_to_parse VARCHAR(255);
DECLARE temp_reception_ids VARCHAR(255);
DECLARE c*** INT;
SET temp_reception_ids = param_reception_ids;
SET serial_no_ids = '';
SET c*** = 0;
WHILE (length(temp_reception_ids) > 0) DO
SET id_to_parse = SUBSTRING_INDEX(temp_reception_ids, ';', 1);
SET serial_no_ids = concat(serial_no_ids, '-', id_to_parse);
<Some 200 more lines, in which 'c***' makes absolutely no appearance whatsoever>
SET temp_reception_ids = SUBSTRING(temp_reception_ids, length(id_to_parse) + 2, length(temp_reception_ids));
SELECT id_to_parse, temp_reception_ids;
SET c*** = c*** + 1;
END WHILE;
END;
No variable or method names have been replaced. That would've taken away all the beauty of it.
Now, what I've actually been amused exactly, is that besides the funny (intended or not) misspelling of 'count' - and yes, I know CP will replace the variable name with '*', is that absolutely no-one knows what the counter was supposed to be used for. Counting the while steps maybe?
However, on the grander scheme of things, this proc is actually quite ok, and it even has comments (and yes, they were useful)!! And what it was supposed to do was this:
- Take a string parameter that contained some IDs separated by ';'
- Take each id from that string and do some selects using that id as parameter
- Extract data from those selects and do some inserts / updates with it, depending on some other conditions
But again, that count, and its associated comment, just made my day!
Full-fledged Java/.NET lover, full-fledged PHP hater.
Full-fledged Google/Microsoft lover, full-fledged Apple hater.
Full-fledged Skype lover, full-fledged YM hater.
|
|
|
|
|
That is defensive coding; adding a "just in case you need it" counter.
Just because the code works, it doesn't mean that it is good code.
|
|
|
|
|
|
CIDev wrote: defensive offensive coding
FTFY
|
|
|
|
|
Andrei Straut wrote: Counting the while steps maybe That would be my guess. I have used counters when debugging code to count the number of times I went through a loop and append that number to a string so I could track the progress. It made it easier to find the offending record.
The only thing I can think of is that it was suggested to this particular developer to use a counter for this reason but the developer didn't understand why they were being told to do this.
It was broke, so I fixed it.
|
|
|
|
|
Hi all,
I was already reading this forum when it was still called the "Hall of shame".
I've got a product to maintain that was created by a developer who is no longer working for us.
Even though I've already seen plenty of "hall of shame worthy" code there, I've have never posted it here, because it would have been my first post on CP ever and I thought it is a bad idea to say hello to a community while bashing an ex colleague.
However, I came across a piece of code that I can't keep for myself and so I'll do what I didn't want to do and bash in my first post:
At the end of a long method I found this one:
try
{
return true;
}
catch (Exception)
{
return false;
}
Cheers,
cmger
|
|
|
|
|
Welcome to posting on CP.
I hope that there used to be more code in the try catch that would give it a reason to be there. Even if there used to be code that justified the try, when that code was removed the try/catch should have also been removed.
This is another fine example of code that might work, but really isn't good code, hence my sig.
Just because the code works, it doesn't mean that it is good code.
|
|
|
|
|