How to stay motivated when it feels that senior colleagues aren't?
Clash Royale CLAN TAG#URR8PPP
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty margin-bottom:0;
up vote
21
down vote
favorite
I passed out of my college with a degree in computer science about 2 years back and since then I have worked in a multi-national firm which pays me decently well. I am sincerely interested in technology and in my work and I try to do everything to the best way possible and also learn the maximum out of it. I have a few colleagues who are experienced and really smart and I really enjoy and learn a lot working with them.
However, I feel the same is not true for all my colleagues. There are many others who are simply not interested in technology. When given a problem, they would choose the first available option or they would just look at an existing solution and copy-paste the same. And such colleagues are actually at positions senior to me. My firm is not strictly an IT firm and so people not being very good at technology is not uncommon.
My question is, how do I work with colleagues like those, especially when they are senior to me?
I feel bad (and also sad) when something is done in a way when I know a better way to do the same exists or when someone does something without much effort and I know that had I done the same, I would have put more effort and come up with a better solution. I can go on with more examples but hopefully I have explained the general situation. I can't correct everyone/everything, I am not the smartest person either but at times you know that things are just not as good as they should be.
How do I make my work experience more enjoyable with such colleagues? Also, how do I keep myself continuously motivated when working in such an environment?
PS: While I appreciate all the responses, I am surprised to see so many people advocating sub-standard work as long as you "get it done". Is that what is expected of me as well.
Also, I didn't want this to be a discussion on best ways of writing code which some of this has turned into.
software-industry work-environment colleagues motivation
 |Â
show 10 more comments
up vote
21
down vote
favorite
I passed out of my college with a degree in computer science about 2 years back and since then I have worked in a multi-national firm which pays me decently well. I am sincerely interested in technology and in my work and I try to do everything to the best way possible and also learn the maximum out of it. I have a few colleagues who are experienced and really smart and I really enjoy and learn a lot working with them.
However, I feel the same is not true for all my colleagues. There are many others who are simply not interested in technology. When given a problem, they would choose the first available option or they would just look at an existing solution and copy-paste the same. And such colleagues are actually at positions senior to me. My firm is not strictly an IT firm and so people not being very good at technology is not uncommon.
My question is, how do I work with colleagues like those, especially when they are senior to me?
I feel bad (and also sad) when something is done in a way when I know a better way to do the same exists or when someone does something without much effort and I know that had I done the same, I would have put more effort and come up with a better solution. I can go on with more examples but hopefully I have explained the general situation. I can't correct everyone/everything, I am not the smartest person either but at times you know that things are just not as good as they should be.
How do I make my work experience more enjoyable with such colleagues? Also, how do I keep myself continuously motivated when working in such an environment?
PS: While I appreciate all the responses, I am surprised to see so many people advocating sub-standard work as long as you "get it done". Is that what is expected of me as well.
Also, I didn't want this to be a discussion on best ways of writing code which some of this has turned into.
software-industry work-environment colleagues motivation
3
Never write what you can steal because time is money. Also, code reuse is good if the code is good but I can understand if they are copying bad solutions just to save time. Are you sure that putting extra effort into the task is worth it? If it is a small job it might not be that big of a deal. There is always the temptation to redo someone else's work because you don't like it, it took me a while to get over that urge.
– CincinnatiProgrammer
Feb 14 '13 at 18:35
13
Hate to be blunt, but it's likely the reason they are senior to you is they understand the purpose of business is to make money - not make pretty code or pretty processes. My answer here probably is one of the best ways you can keep yourself motivated.
– Elysian Fields♦
Feb 14 '13 at 19:14
7
@sunny doing business properly is getting results for lower cost. This often (especially in software) can come at the cost of crappy code, bad architecture, poor API utilization, or a whole host of other problems (from "pretty/good software" perspectives) which the customer never sees.
– Elysian Fields♦
Feb 14 '13 at 19:38
7
@Sunny - no surprise there. they teach theory in college, not practice.
– IDrinkandIKnowThings
Feb 14 '13 at 20:19
4
Voted to reopen. I think most people who are passionate about the tech industry have worked in a situation where they asked themselves this question. I often wonder if the people who are on the "other side" of this question are the ones who got beat down before they found an answer that brought them peace.
– Amy Blankenship
Feb 15 '13 at 0:21
 |Â
show 10 more comments
up vote
21
down vote
favorite
up vote
21
down vote
favorite
I passed out of my college with a degree in computer science about 2 years back and since then I have worked in a multi-national firm which pays me decently well. I am sincerely interested in technology and in my work and I try to do everything to the best way possible and also learn the maximum out of it. I have a few colleagues who are experienced and really smart and I really enjoy and learn a lot working with them.
However, I feel the same is not true for all my colleagues. There are many others who are simply not interested in technology. When given a problem, they would choose the first available option or they would just look at an existing solution and copy-paste the same. And such colleagues are actually at positions senior to me. My firm is not strictly an IT firm and so people not being very good at technology is not uncommon.
My question is, how do I work with colleagues like those, especially when they are senior to me?
I feel bad (and also sad) when something is done in a way when I know a better way to do the same exists or when someone does something without much effort and I know that had I done the same, I would have put more effort and come up with a better solution. I can go on with more examples but hopefully I have explained the general situation. I can't correct everyone/everything, I am not the smartest person either but at times you know that things are just not as good as they should be.
How do I make my work experience more enjoyable with such colleagues? Also, how do I keep myself continuously motivated when working in such an environment?
PS: While I appreciate all the responses, I am surprised to see so many people advocating sub-standard work as long as you "get it done". Is that what is expected of me as well.
Also, I didn't want this to be a discussion on best ways of writing code which some of this has turned into.
software-industry work-environment colleagues motivation
I passed out of my college with a degree in computer science about 2 years back and since then I have worked in a multi-national firm which pays me decently well. I am sincerely interested in technology and in my work and I try to do everything to the best way possible and also learn the maximum out of it. I have a few colleagues who are experienced and really smart and I really enjoy and learn a lot working with them.
However, I feel the same is not true for all my colleagues. There are many others who are simply not interested in technology. When given a problem, they would choose the first available option or they would just look at an existing solution and copy-paste the same. And such colleagues are actually at positions senior to me. My firm is not strictly an IT firm and so people not being very good at technology is not uncommon.
My question is, how do I work with colleagues like those, especially when they are senior to me?
I feel bad (and also sad) when something is done in a way when I know a better way to do the same exists or when someone does something without much effort and I know that had I done the same, I would have put more effort and come up with a better solution. I can go on with more examples but hopefully I have explained the general situation. I can't correct everyone/everything, I am not the smartest person either but at times you know that things are just not as good as they should be.
How do I make my work experience more enjoyable with such colleagues? Also, how do I keep myself continuously motivated when working in such an environment?
PS: While I appreciate all the responses, I am surprised to see so many people advocating sub-standard work as long as you "get it done". Is that what is expected of me as well.
Also, I didn't want this to be a discussion on best ways of writing code which some of this has turned into.
software-industry work-environment colleagues motivation
edited Feb 15 '13 at 8:53
gnat
3,23273066
3,23273066
asked Feb 14 '13 at 18:24
sunny
5131610
5131610
3
Never write what you can steal because time is money. Also, code reuse is good if the code is good but I can understand if they are copying bad solutions just to save time. Are you sure that putting extra effort into the task is worth it? If it is a small job it might not be that big of a deal. There is always the temptation to redo someone else's work because you don't like it, it took me a while to get over that urge.
– CincinnatiProgrammer
Feb 14 '13 at 18:35
13
Hate to be blunt, but it's likely the reason they are senior to you is they understand the purpose of business is to make money - not make pretty code or pretty processes. My answer here probably is one of the best ways you can keep yourself motivated.
– Elysian Fields♦
Feb 14 '13 at 19:14
7
@sunny doing business properly is getting results for lower cost. This often (especially in software) can come at the cost of crappy code, bad architecture, poor API utilization, or a whole host of other problems (from "pretty/good software" perspectives) which the customer never sees.
– Elysian Fields♦
Feb 14 '13 at 19:38
7
@Sunny - no surprise there. they teach theory in college, not practice.
– IDrinkandIKnowThings
Feb 14 '13 at 20:19
4
Voted to reopen. I think most people who are passionate about the tech industry have worked in a situation where they asked themselves this question. I often wonder if the people who are on the "other side" of this question are the ones who got beat down before they found an answer that brought them peace.
– Amy Blankenship
Feb 15 '13 at 0:21
 |Â
show 10 more comments
3
Never write what you can steal because time is money. Also, code reuse is good if the code is good but I can understand if they are copying bad solutions just to save time. Are you sure that putting extra effort into the task is worth it? If it is a small job it might not be that big of a deal. There is always the temptation to redo someone else's work because you don't like it, it took me a while to get over that urge.
– CincinnatiProgrammer
Feb 14 '13 at 18:35
13
Hate to be blunt, but it's likely the reason they are senior to you is they understand the purpose of business is to make money - not make pretty code or pretty processes. My answer here probably is one of the best ways you can keep yourself motivated.
– Elysian Fields♦
Feb 14 '13 at 19:14
7
@sunny doing business properly is getting results for lower cost. This often (especially in software) can come at the cost of crappy code, bad architecture, poor API utilization, or a whole host of other problems (from "pretty/good software" perspectives) which the customer never sees.
– Elysian Fields♦
Feb 14 '13 at 19:38
7
@Sunny - no surprise there. they teach theory in college, not practice.
– IDrinkandIKnowThings
Feb 14 '13 at 20:19
4
Voted to reopen. I think most people who are passionate about the tech industry have worked in a situation where they asked themselves this question. I often wonder if the people who are on the "other side" of this question are the ones who got beat down before they found an answer that brought them peace.
– Amy Blankenship
Feb 15 '13 at 0:21
3
3
Never write what you can steal because time is money. Also, code reuse is good if the code is good but I can understand if they are copying bad solutions just to save time. Are you sure that putting extra effort into the task is worth it? If it is a small job it might not be that big of a deal. There is always the temptation to redo someone else's work because you don't like it, it took me a while to get over that urge.
– CincinnatiProgrammer
Feb 14 '13 at 18:35
Never write what you can steal because time is money. Also, code reuse is good if the code is good but I can understand if they are copying bad solutions just to save time. Are you sure that putting extra effort into the task is worth it? If it is a small job it might not be that big of a deal. There is always the temptation to redo someone else's work because you don't like it, it took me a while to get over that urge.
– CincinnatiProgrammer
Feb 14 '13 at 18:35
13
13
Hate to be blunt, but it's likely the reason they are senior to you is they understand the purpose of business is to make money - not make pretty code or pretty processes. My answer here probably is one of the best ways you can keep yourself motivated.
– Elysian Fields♦
Feb 14 '13 at 19:14
Hate to be blunt, but it's likely the reason they are senior to you is they understand the purpose of business is to make money - not make pretty code or pretty processes. My answer here probably is one of the best ways you can keep yourself motivated.
– Elysian Fields♦
Feb 14 '13 at 19:14
7
7
@sunny doing business properly is getting results for lower cost. This often (especially in software) can come at the cost of crappy code, bad architecture, poor API utilization, or a whole host of other problems (from "pretty/good software" perspectives) which the customer never sees.
– Elysian Fields♦
Feb 14 '13 at 19:38
@sunny doing business properly is getting results for lower cost. This often (especially in software) can come at the cost of crappy code, bad architecture, poor API utilization, or a whole host of other problems (from "pretty/good software" perspectives) which the customer never sees.
– Elysian Fields♦
Feb 14 '13 at 19:38
7
7
@Sunny - no surprise there. they teach theory in college, not practice.
– IDrinkandIKnowThings
Feb 14 '13 at 20:19
@Sunny - no surprise there. they teach theory in college, not practice.
– IDrinkandIKnowThings
Feb 14 '13 at 20:19
4
4
Voted to reopen. I think most people who are passionate about the tech industry have worked in a situation where they asked themselves this question. I often wonder if the people who are on the "other side" of this question are the ones who got beat down before they found an answer that brought them peace.
– Amy Blankenship
Feb 15 '13 at 0:21
Voted to reopen. I think most people who are passionate about the tech industry have worked in a situation where they asked themselves this question. I often wonder if the people who are on the "other side" of this question are the ones who got beat down before they found an answer that brought them peace.
– Amy Blankenship
Feb 15 '13 at 0:21
 |Â
show 10 more comments
4 Answers
4
active
oldest
votes
up vote
27
down vote
accepted
I have been in your situation more times than I care to remember. I got my first IT-related job in 1984, and I've been going ever since. In many jobs I've held, I've worked with people who were more interested in "getting it done" with no thought to the future impact or overall design approach. I've worked with people who were simply content with doing as little as possible and enjoyed getting paid at a level which reflected the market, rather than their contribution. I've also worked with people who were passionate about the work they do, and wanted to provide quality service and products. I've worked with people who may have been socially challenged, but their brilliance reflected in their work ethic and sense of ownership of their tasks and assignments.
In all of the situations I have mentioned, the common thread is that I was able to learn something from all of them, no matter how seemingly unimportant or philosophy-changing it was at the time. Your coworkers are going to be driven by different objectives. Some simply need to provide themselves and/or their family with security. Some need the money commanded by IT professionals to feed their material needs and desire for status. Some would do the work for half of what they are getting, just for the personal satisfaction of doing a good job. In any case, your best approach when dealing with your coworkers may to be to simply accept that the people around may not be guided by the same drives as you. It doesn't make them less worthy of your respect and support, because they are your teammates.
That being said, just as you should accept them for what you perceive to be their shortcomings, they should also accept you for what they may believe to be your shortcomings. You have to be true to yourself and what drives you. If you want things to be a certain way on your projects, you should be able to do whatever you believe to be best. You can't expect them to adopt your approach, but you can make suggestions. If they choose not to implement your ideas, so be it. Don't feel rejected or slighted, because, as long as you are following the approach that suits you, your work will get done. Over time, you may acquire some converts and you may see some implementation strategies they are using that you wish to adopt. Everyone can learn from each other. The challenge is the removal of the assumption that because this person is not doing it the way I am doing it, he/she is doing it the wrong way.
Thanks, your answer is great, a little hard to put in practice or so i think , but i like it. We should accept people as they are and learn from them what they are good at.
– sunny
Feb 14 '13 at 19:34
I think this is a very mature and respectable answer.
– James
Jul 5 '14 at 12:14
add a comment |Â
up vote
11
down vote
I think there are several things you can do to stay motivated.
First, realize you are not alone. Look around this forum. There are actually many questions that are similar to yours, although most are less direct. I've actually had the experience of being hired because I knew best practices, but wasn't allowed to implement best practices very much at all.
I think that it's easy to form a world-view where you imagine your conception of excellence is important to everyone. After all, in school you are taught certain things as best practices and the bloggers you look up to take those ideas as read. But that world is invisible to many "average" developers, and even those who know about it may not feel it is as important as you do. However, simply knowing that you're not crazy, that other people encounter brick walls when they want to implement all these good things, will help you keep your sanity.
This is not to say that you should lose your drive: don't. My completely made-up estimate is that maybe 25% of developers really have it. Eventually, you will find a place in life where the drive works for you rather than frustrating you, and when you do, it will be rewarding in a way those 75% of developers may never experience (this may or may not be financial rewards).Stay positive. The very fact that you posted the question indicates that you know that there's a risk of getting mired in negative thoughts as your frustration eats away at you. If you find this happening, find ways to turn your thoughts to positive things. Go for a walk or listen to some happy music while you work. Really dig into what you are doing and block out the things that others are doing that frustrate you.
One thing that will help you stay positive is to avoid ascribing motives to others. All you know is that your frustrating coworkers don't want what you want them to want. Let them worry about why. Stop thinking even that they are unmotivated. They may be very motivated, but in ways that you don't care about.Consider the issue from other perspectives. One thing my boss tells me on a frequent basis is he doesn't even care if it's faster to do things one way vs. another way. What he really wants is to have a really good idea of exactly how long something will take. If you always do something the same way, it fulfils that goal, to most people.
Looking at the other side of things, trying a radically different approach, even if it is better practice, carries a significant risk that you might not meet deadline. From that perspective, trying approaches other than the tried and true is actually a bit unethical--you're doing something for your own mental health that may not be good for the health of the business.
Many developers and managers do not realize that good code actually makes it possible to make more reliable estimates. However, since you are only two years out of school, consider the possibility that you may not yet be ready to write that kind of code and letting you spend the time learning it could cause the company to miss some key deadlines, even if it's great for you.Work for change. Put some skin in the game, and take some of your personal time to put together a demo of the techniques that you feel should be put into place. When you make your pitch, be really careful not to say anything that sounds like a criticism of any person, and try to avoid saying "this tehcnique is bad." Instead say "I think if we did X, it would save us 30% or more of the time that we take to do task Y compared to what we're doing now." Stick to this non-critical, non-accusatory strategy even if you're asked leading questions like "But I thought we already were using best practices. Why aren't we doing this?" I followed this strategy, and I wound up getting the green light to rewrite our entire codebase.
By doing this, you might be able to put enough of a prototype out there to demonstrate that, just because you're not the most experienced member of the team, doesn't mean you can't write solid code. And you might learn enough from this that even if you're told "no," you're better able to write that type of code in the future (at this job or another).
You may be told "no," but people will remember that you took a stand. That may move the needle a bit, since you said not everyone is unmotivated. If you really believe this is the best way to do things, don't let it go, but be wise in how you press the issue. For example, when I came back from vacation and I was asked to make a change that I couldn't make because the site had been changed in ways that I had no way to know about, I pointed out to my boss that if the site had been under version control, I could have looked in the log and just seen what happened. But I would not have made that comment in front of other employees. These types of comments can seem snarky, so use them sparingly and only in one-on-one conversation. The odds someone will think they are snarky goes up exponentially based on the audience size.Build support. Consciously cultivate your "experienced and really smart" colleagues. Go to lunch together and discuss what's bugging you (in a positive way like "I had this idea..."). If they know what you think and you know what they think, when you're in meetings it is very likely that they will naturally join their voices to yours or vice versa. In fact, you should seek out opportunities to support anyone who is doing anything like offering a best practice idea, whether you previously knew this person was interested in best practice or not.
After you have built a good base among the likeminded developers, see if you can cultivate the ones you don't see as motivated. For one thing, they might surprise you. For another, they're less likely to out-and-out block you if you have a personal friendship.Realize this job is not your life, and may not be your future. You are not stuck in this job, but while you are at it, milk it for everything you can in terms of what you can learn. Maybe they will never appreciate the fire you bring to the job. That's ok--learning how to live in a job that doesn't "get" you is a valuable skill. But once you feel that you're ready to spread your wings, if you see a better opportunity, go for it. Thinking of the job as just what's going on "right now," rather than "how it will be forever" can change your attitude a lot.
Give it time. I once had a boss (who was on the verge of retiring) who told me "Amy, you don't have to get so angry. Just do what you do and eventually people will start to realize you're right a lot." It takes time to build cred, and teams don't change overnight just because you point out that they should. Give your ideas time to sink in and keep plugging, and maybe in time you'll look up and realize that things have changed a lot, for the better, in less time than you were afraid of. This happened to me :).
add a comment |Â
up vote
0
down vote
When given a problem, they would choose the first available option or they would just look at an existing solution and copy-paste the same. And such colleagues are actually at positions senior to me.
........
I feel bad (and also sad) when something is done in a way when I know a better way to do the same exists
Your colleagues may be in a position senior to you because they're able to get stuff done quickly, and effectively.
When you say that a "better way" exists, are you saying that the way it was done was not elegant, not "pretty", and that you had a slicker way to accomplish the same? Or are you saying that your colleagues are putting out dangerous, un-secure code, or code that will be terribly difficult to maintain and scale?
If the first is the case, then welcome to the real world. Companies want stuff done quickly, since time is money.
If you're dealing with the second, then it sounds like you're in a terrible company with poor management. Suck it up, learn as much as you can, then move on to a better opportunity when you have the chance.
add a comment |Â
up vote
0
down vote
I have no idea how CS degrees work where you're from, but from what I've seen, they have very little to do with the work of a software engineer. Academia is famously shielded from the real world.
The hard part is striking a balance between some untangible ideal and the "it just works" solution. Either of the extremes work, in fact - in some environments. If you're making contract end-user stuff with no prospects at maintenance, "just getting it done" is a valid philosophy. When you're writing Shuttle software, you've got a lot more time to polish.
When you're trying to change the approach of the people around you, make sure to actually be sure about the benefits. Build up the pro's and con's, estimate the costs associated with "bad solutions", and the costs associated with "proper code" - neither is free. If you're lucky, the people around you understand opportunity costs - that makes it much easier to go towards better architecture, better code. If the code takes twice as long to write, but is half as much work to maintain and extend, you want to show that that cost actually pays back at some point, with reasonable certainty.
Customer satisfaction is also a hugely important factor. If the choice is between better code and better user experience, UX always wins, and it should. Again, the biggest tipping factor is when better code leads to better UX in the future - will the impact of better code be enough to make it cheaper in the end? Good code is often an investment, not something of value out of the box; rarely will you find an opportunity when good code gives better efficiency on the original task (note that I'm talking about "bad" code produced by good programmers - if your programmers are simply bad and sloppy, you're out of luck); the payback usually comes further down the road, if at all.
People have trouble thinking about investments. Get some numbers. It can be very helpful if you can actually gather some data from the past - when you suggest some architectural or code quality change, write it down. When the time comes and your suggestion would save time or improve customer satisfaction - write it down. When you have enough, go to your managers, seniors, whoever - it's easier to argue when you've got "hard" data in your hands.
The reverse applies too. Don't assume that "better" code is automatically better. I've seen many cases where the programmers were losing way too much time working out things that didn't matter - on a test application that was only there for one scenario and thrown away, elsewhere creating an architecture that was overly complicated and in the end inhibited further development.
Perfect is rarely good. If your backlog isn't full of (minor) bugs and feature requests that you simply don't have the time and resources to fix, you're probably doing something wrong, and your competition is gaining on you.
I'm usually thinking in terms of time or money. Translating things to money helps a lot in cost-benefit calculations. This took me a bit more work, and I got some experience from it. How much would I pay for that knowledge, was it worth it? It will save me some time down the road - is it enough? What will be the cost if I don't do it that way and it will turn out to be a bad decision down the road? It's crucial to know how much time was spent fixing bugs on the original task, otherwise the perception gets extremely skewed. If something took me 4 hours, just as estimated, but then I spent 20 hours fixing the bugs, it has to be visible that my estimate was way off.
It takes a lot of pushing if you're "the only one". But it can be done, you can move to better practices, better code, better software. Just make sure that in the end, it's actually better in some measurable way.
add a comment |Â
StackExchange.ready(function ()
$("#show-editor-button input, #show-editor-button button").click(function ()
var showEditor = function()
$("#show-editor-button").hide();
$("#post-form").removeClass("dno");
StackExchange.editor.finallyInit();
;
var useFancy = $(this).data('confirm-use-fancy');
if(useFancy == 'True')
var popupTitle = $(this).data('confirm-fancy-title');
var popupBody = $(this).data('confirm-fancy-body');
var popupAccept = $(this).data('confirm-fancy-accept-button');
$(this).loadPopup(
url: '/post/self-answer-popup',
loaded: function(popup)
var pTitle = $(popup).find('h2');
var pBody = $(popup).find('.popup-body');
var pSubmit = $(popup).find('.popup-submit');
pTitle.text(popupTitle);
pBody.html(popupBody);
pSubmit.val(popupAccept).click(showEditor);
)
else
var confirmText = $(this).data('confirm-text');
if (confirmText ? confirm(confirmText) : true)
showEditor();
);
);
4 Answers
4
active
oldest
votes
4 Answers
4
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
27
down vote
accepted
I have been in your situation more times than I care to remember. I got my first IT-related job in 1984, and I've been going ever since. In many jobs I've held, I've worked with people who were more interested in "getting it done" with no thought to the future impact or overall design approach. I've worked with people who were simply content with doing as little as possible and enjoyed getting paid at a level which reflected the market, rather than their contribution. I've also worked with people who were passionate about the work they do, and wanted to provide quality service and products. I've worked with people who may have been socially challenged, but their brilliance reflected in their work ethic and sense of ownership of their tasks and assignments.
In all of the situations I have mentioned, the common thread is that I was able to learn something from all of them, no matter how seemingly unimportant or philosophy-changing it was at the time. Your coworkers are going to be driven by different objectives. Some simply need to provide themselves and/or their family with security. Some need the money commanded by IT professionals to feed their material needs and desire for status. Some would do the work for half of what they are getting, just for the personal satisfaction of doing a good job. In any case, your best approach when dealing with your coworkers may to be to simply accept that the people around may not be guided by the same drives as you. It doesn't make them less worthy of your respect and support, because they are your teammates.
That being said, just as you should accept them for what you perceive to be their shortcomings, they should also accept you for what they may believe to be your shortcomings. You have to be true to yourself and what drives you. If you want things to be a certain way on your projects, you should be able to do whatever you believe to be best. You can't expect them to adopt your approach, but you can make suggestions. If they choose not to implement your ideas, so be it. Don't feel rejected or slighted, because, as long as you are following the approach that suits you, your work will get done. Over time, you may acquire some converts and you may see some implementation strategies they are using that you wish to adopt. Everyone can learn from each other. The challenge is the removal of the assumption that because this person is not doing it the way I am doing it, he/she is doing it the wrong way.
Thanks, your answer is great, a little hard to put in practice or so i think , but i like it. We should accept people as they are and learn from them what they are good at.
– sunny
Feb 14 '13 at 19:34
I think this is a very mature and respectable answer.
– James
Jul 5 '14 at 12:14
add a comment |Â
up vote
27
down vote
accepted
I have been in your situation more times than I care to remember. I got my first IT-related job in 1984, and I've been going ever since. In many jobs I've held, I've worked with people who were more interested in "getting it done" with no thought to the future impact or overall design approach. I've worked with people who were simply content with doing as little as possible and enjoyed getting paid at a level which reflected the market, rather than their contribution. I've also worked with people who were passionate about the work they do, and wanted to provide quality service and products. I've worked with people who may have been socially challenged, but their brilliance reflected in their work ethic and sense of ownership of their tasks and assignments.
In all of the situations I have mentioned, the common thread is that I was able to learn something from all of them, no matter how seemingly unimportant or philosophy-changing it was at the time. Your coworkers are going to be driven by different objectives. Some simply need to provide themselves and/or their family with security. Some need the money commanded by IT professionals to feed their material needs and desire for status. Some would do the work for half of what they are getting, just for the personal satisfaction of doing a good job. In any case, your best approach when dealing with your coworkers may to be to simply accept that the people around may not be guided by the same drives as you. It doesn't make them less worthy of your respect and support, because they are your teammates.
That being said, just as you should accept them for what you perceive to be their shortcomings, they should also accept you for what they may believe to be your shortcomings. You have to be true to yourself and what drives you. If you want things to be a certain way on your projects, you should be able to do whatever you believe to be best. You can't expect them to adopt your approach, but you can make suggestions. If they choose not to implement your ideas, so be it. Don't feel rejected or slighted, because, as long as you are following the approach that suits you, your work will get done. Over time, you may acquire some converts and you may see some implementation strategies they are using that you wish to adopt. Everyone can learn from each other. The challenge is the removal of the assumption that because this person is not doing it the way I am doing it, he/she is doing it the wrong way.
Thanks, your answer is great, a little hard to put in practice or so i think , but i like it. We should accept people as they are and learn from them what they are good at.
– sunny
Feb 14 '13 at 19:34
I think this is a very mature and respectable answer.
– James
Jul 5 '14 at 12:14
add a comment |Â
up vote
27
down vote
accepted
up vote
27
down vote
accepted
I have been in your situation more times than I care to remember. I got my first IT-related job in 1984, and I've been going ever since. In many jobs I've held, I've worked with people who were more interested in "getting it done" with no thought to the future impact or overall design approach. I've worked with people who were simply content with doing as little as possible and enjoyed getting paid at a level which reflected the market, rather than their contribution. I've also worked with people who were passionate about the work they do, and wanted to provide quality service and products. I've worked with people who may have been socially challenged, but their brilliance reflected in their work ethic and sense of ownership of their tasks and assignments.
In all of the situations I have mentioned, the common thread is that I was able to learn something from all of them, no matter how seemingly unimportant or philosophy-changing it was at the time. Your coworkers are going to be driven by different objectives. Some simply need to provide themselves and/or their family with security. Some need the money commanded by IT professionals to feed their material needs and desire for status. Some would do the work for half of what they are getting, just for the personal satisfaction of doing a good job. In any case, your best approach when dealing with your coworkers may to be to simply accept that the people around may not be guided by the same drives as you. It doesn't make them less worthy of your respect and support, because they are your teammates.
That being said, just as you should accept them for what you perceive to be their shortcomings, they should also accept you for what they may believe to be your shortcomings. You have to be true to yourself and what drives you. If you want things to be a certain way on your projects, you should be able to do whatever you believe to be best. You can't expect them to adopt your approach, but you can make suggestions. If they choose not to implement your ideas, so be it. Don't feel rejected or slighted, because, as long as you are following the approach that suits you, your work will get done. Over time, you may acquire some converts and you may see some implementation strategies they are using that you wish to adopt. Everyone can learn from each other. The challenge is the removal of the assumption that because this person is not doing it the way I am doing it, he/she is doing it the wrong way.
I have been in your situation more times than I care to remember. I got my first IT-related job in 1984, and I've been going ever since. In many jobs I've held, I've worked with people who were more interested in "getting it done" with no thought to the future impact or overall design approach. I've worked with people who were simply content with doing as little as possible and enjoyed getting paid at a level which reflected the market, rather than their contribution. I've also worked with people who were passionate about the work they do, and wanted to provide quality service and products. I've worked with people who may have been socially challenged, but their brilliance reflected in their work ethic and sense of ownership of their tasks and assignments.
In all of the situations I have mentioned, the common thread is that I was able to learn something from all of them, no matter how seemingly unimportant or philosophy-changing it was at the time. Your coworkers are going to be driven by different objectives. Some simply need to provide themselves and/or their family with security. Some need the money commanded by IT professionals to feed their material needs and desire for status. Some would do the work for half of what they are getting, just for the personal satisfaction of doing a good job. In any case, your best approach when dealing with your coworkers may to be to simply accept that the people around may not be guided by the same drives as you. It doesn't make them less worthy of your respect and support, because they are your teammates.
That being said, just as you should accept them for what you perceive to be their shortcomings, they should also accept you for what they may believe to be your shortcomings. You have to be true to yourself and what drives you. If you want things to be a certain way on your projects, you should be able to do whatever you believe to be best. You can't expect them to adopt your approach, but you can make suggestions. If they choose not to implement your ideas, so be it. Don't feel rejected or slighted, because, as long as you are following the approach that suits you, your work will get done. Over time, you may acquire some converts and you may see some implementation strategies they are using that you wish to adopt. Everyone can learn from each other. The challenge is the removal of the assumption that because this person is not doing it the way I am doing it, he/she is doing it the wrong way.
answered Feb 14 '13 at 18:48
Neil T.
5,01711826
5,01711826
Thanks, your answer is great, a little hard to put in practice or so i think , but i like it. We should accept people as they are and learn from them what they are good at.
– sunny
Feb 14 '13 at 19:34
I think this is a very mature and respectable answer.
– James
Jul 5 '14 at 12:14
add a comment |Â
Thanks, your answer is great, a little hard to put in practice or so i think , but i like it. We should accept people as they are and learn from them what they are good at.
– sunny
Feb 14 '13 at 19:34
I think this is a very mature and respectable answer.
– James
Jul 5 '14 at 12:14
Thanks, your answer is great, a little hard to put in practice or so i think , but i like it. We should accept people as they are and learn from them what they are good at.
– sunny
Feb 14 '13 at 19:34
Thanks, your answer is great, a little hard to put in practice or so i think , but i like it. We should accept people as they are and learn from them what they are good at.
– sunny
Feb 14 '13 at 19:34
I think this is a very mature and respectable answer.
– James
Jul 5 '14 at 12:14
I think this is a very mature and respectable answer.
– James
Jul 5 '14 at 12:14
add a comment |Â
up vote
11
down vote
I think there are several things you can do to stay motivated.
First, realize you are not alone. Look around this forum. There are actually many questions that are similar to yours, although most are less direct. I've actually had the experience of being hired because I knew best practices, but wasn't allowed to implement best practices very much at all.
I think that it's easy to form a world-view where you imagine your conception of excellence is important to everyone. After all, in school you are taught certain things as best practices and the bloggers you look up to take those ideas as read. But that world is invisible to many "average" developers, and even those who know about it may not feel it is as important as you do. However, simply knowing that you're not crazy, that other people encounter brick walls when they want to implement all these good things, will help you keep your sanity.
This is not to say that you should lose your drive: don't. My completely made-up estimate is that maybe 25% of developers really have it. Eventually, you will find a place in life where the drive works for you rather than frustrating you, and when you do, it will be rewarding in a way those 75% of developers may never experience (this may or may not be financial rewards).Stay positive. The very fact that you posted the question indicates that you know that there's a risk of getting mired in negative thoughts as your frustration eats away at you. If you find this happening, find ways to turn your thoughts to positive things. Go for a walk or listen to some happy music while you work. Really dig into what you are doing and block out the things that others are doing that frustrate you.
One thing that will help you stay positive is to avoid ascribing motives to others. All you know is that your frustrating coworkers don't want what you want them to want. Let them worry about why. Stop thinking even that they are unmotivated. They may be very motivated, but in ways that you don't care about.Consider the issue from other perspectives. One thing my boss tells me on a frequent basis is he doesn't even care if it's faster to do things one way vs. another way. What he really wants is to have a really good idea of exactly how long something will take. If you always do something the same way, it fulfils that goal, to most people.
Looking at the other side of things, trying a radically different approach, even if it is better practice, carries a significant risk that you might not meet deadline. From that perspective, trying approaches other than the tried and true is actually a bit unethical--you're doing something for your own mental health that may not be good for the health of the business.
Many developers and managers do not realize that good code actually makes it possible to make more reliable estimates. However, since you are only two years out of school, consider the possibility that you may not yet be ready to write that kind of code and letting you spend the time learning it could cause the company to miss some key deadlines, even if it's great for you.Work for change. Put some skin in the game, and take some of your personal time to put together a demo of the techniques that you feel should be put into place. When you make your pitch, be really careful not to say anything that sounds like a criticism of any person, and try to avoid saying "this tehcnique is bad." Instead say "I think if we did X, it would save us 30% or more of the time that we take to do task Y compared to what we're doing now." Stick to this non-critical, non-accusatory strategy even if you're asked leading questions like "But I thought we already were using best practices. Why aren't we doing this?" I followed this strategy, and I wound up getting the green light to rewrite our entire codebase.
By doing this, you might be able to put enough of a prototype out there to demonstrate that, just because you're not the most experienced member of the team, doesn't mean you can't write solid code. And you might learn enough from this that even if you're told "no," you're better able to write that type of code in the future (at this job or another).
You may be told "no," but people will remember that you took a stand. That may move the needle a bit, since you said not everyone is unmotivated. If you really believe this is the best way to do things, don't let it go, but be wise in how you press the issue. For example, when I came back from vacation and I was asked to make a change that I couldn't make because the site had been changed in ways that I had no way to know about, I pointed out to my boss that if the site had been under version control, I could have looked in the log and just seen what happened. But I would not have made that comment in front of other employees. These types of comments can seem snarky, so use them sparingly and only in one-on-one conversation. The odds someone will think they are snarky goes up exponentially based on the audience size.Build support. Consciously cultivate your "experienced and really smart" colleagues. Go to lunch together and discuss what's bugging you (in a positive way like "I had this idea..."). If they know what you think and you know what they think, when you're in meetings it is very likely that they will naturally join their voices to yours or vice versa. In fact, you should seek out opportunities to support anyone who is doing anything like offering a best practice idea, whether you previously knew this person was interested in best practice or not.
After you have built a good base among the likeminded developers, see if you can cultivate the ones you don't see as motivated. For one thing, they might surprise you. For another, they're less likely to out-and-out block you if you have a personal friendship.Realize this job is not your life, and may not be your future. You are not stuck in this job, but while you are at it, milk it for everything you can in terms of what you can learn. Maybe they will never appreciate the fire you bring to the job. That's ok--learning how to live in a job that doesn't "get" you is a valuable skill. But once you feel that you're ready to spread your wings, if you see a better opportunity, go for it. Thinking of the job as just what's going on "right now," rather than "how it will be forever" can change your attitude a lot.
Give it time. I once had a boss (who was on the verge of retiring) who told me "Amy, you don't have to get so angry. Just do what you do and eventually people will start to realize you're right a lot." It takes time to build cred, and teams don't change overnight just because you point out that they should. Give your ideas time to sink in and keep plugging, and maybe in time you'll look up and realize that things have changed a lot, for the better, in less time than you were afraid of. This happened to me :).
add a comment |Â
up vote
11
down vote
I think there are several things you can do to stay motivated.
First, realize you are not alone. Look around this forum. There are actually many questions that are similar to yours, although most are less direct. I've actually had the experience of being hired because I knew best practices, but wasn't allowed to implement best practices very much at all.
I think that it's easy to form a world-view where you imagine your conception of excellence is important to everyone. After all, in school you are taught certain things as best practices and the bloggers you look up to take those ideas as read. But that world is invisible to many "average" developers, and even those who know about it may not feel it is as important as you do. However, simply knowing that you're not crazy, that other people encounter brick walls when they want to implement all these good things, will help you keep your sanity.
This is not to say that you should lose your drive: don't. My completely made-up estimate is that maybe 25% of developers really have it. Eventually, you will find a place in life where the drive works for you rather than frustrating you, and when you do, it will be rewarding in a way those 75% of developers may never experience (this may or may not be financial rewards).Stay positive. The very fact that you posted the question indicates that you know that there's a risk of getting mired in negative thoughts as your frustration eats away at you. If you find this happening, find ways to turn your thoughts to positive things. Go for a walk or listen to some happy music while you work. Really dig into what you are doing and block out the things that others are doing that frustrate you.
One thing that will help you stay positive is to avoid ascribing motives to others. All you know is that your frustrating coworkers don't want what you want them to want. Let them worry about why. Stop thinking even that they are unmotivated. They may be very motivated, but in ways that you don't care about.Consider the issue from other perspectives. One thing my boss tells me on a frequent basis is he doesn't even care if it's faster to do things one way vs. another way. What he really wants is to have a really good idea of exactly how long something will take. If you always do something the same way, it fulfils that goal, to most people.
Looking at the other side of things, trying a radically different approach, even if it is better practice, carries a significant risk that you might not meet deadline. From that perspective, trying approaches other than the tried and true is actually a bit unethical--you're doing something for your own mental health that may not be good for the health of the business.
Many developers and managers do not realize that good code actually makes it possible to make more reliable estimates. However, since you are only two years out of school, consider the possibility that you may not yet be ready to write that kind of code and letting you spend the time learning it could cause the company to miss some key deadlines, even if it's great for you.Work for change. Put some skin in the game, and take some of your personal time to put together a demo of the techniques that you feel should be put into place. When you make your pitch, be really careful not to say anything that sounds like a criticism of any person, and try to avoid saying "this tehcnique is bad." Instead say "I think if we did X, it would save us 30% or more of the time that we take to do task Y compared to what we're doing now." Stick to this non-critical, non-accusatory strategy even if you're asked leading questions like "But I thought we already were using best practices. Why aren't we doing this?" I followed this strategy, and I wound up getting the green light to rewrite our entire codebase.
By doing this, you might be able to put enough of a prototype out there to demonstrate that, just because you're not the most experienced member of the team, doesn't mean you can't write solid code. And you might learn enough from this that even if you're told "no," you're better able to write that type of code in the future (at this job or another).
You may be told "no," but people will remember that you took a stand. That may move the needle a bit, since you said not everyone is unmotivated. If you really believe this is the best way to do things, don't let it go, but be wise in how you press the issue. For example, when I came back from vacation and I was asked to make a change that I couldn't make because the site had been changed in ways that I had no way to know about, I pointed out to my boss that if the site had been under version control, I could have looked in the log and just seen what happened. But I would not have made that comment in front of other employees. These types of comments can seem snarky, so use them sparingly and only in one-on-one conversation. The odds someone will think they are snarky goes up exponentially based on the audience size.Build support. Consciously cultivate your "experienced and really smart" colleagues. Go to lunch together and discuss what's bugging you (in a positive way like "I had this idea..."). If they know what you think and you know what they think, when you're in meetings it is very likely that they will naturally join their voices to yours or vice versa. In fact, you should seek out opportunities to support anyone who is doing anything like offering a best practice idea, whether you previously knew this person was interested in best practice or not.
After you have built a good base among the likeminded developers, see if you can cultivate the ones you don't see as motivated. For one thing, they might surprise you. For another, they're less likely to out-and-out block you if you have a personal friendship.Realize this job is not your life, and may not be your future. You are not stuck in this job, but while you are at it, milk it for everything you can in terms of what you can learn. Maybe they will never appreciate the fire you bring to the job. That's ok--learning how to live in a job that doesn't "get" you is a valuable skill. But once you feel that you're ready to spread your wings, if you see a better opportunity, go for it. Thinking of the job as just what's going on "right now," rather than "how it will be forever" can change your attitude a lot.
Give it time. I once had a boss (who was on the verge of retiring) who told me "Amy, you don't have to get so angry. Just do what you do and eventually people will start to realize you're right a lot." It takes time to build cred, and teams don't change overnight just because you point out that they should. Give your ideas time to sink in and keep plugging, and maybe in time you'll look up and realize that things have changed a lot, for the better, in less time than you were afraid of. This happened to me :).
add a comment |Â
up vote
11
down vote
up vote
11
down vote
I think there are several things you can do to stay motivated.
First, realize you are not alone. Look around this forum. There are actually many questions that are similar to yours, although most are less direct. I've actually had the experience of being hired because I knew best practices, but wasn't allowed to implement best practices very much at all.
I think that it's easy to form a world-view where you imagine your conception of excellence is important to everyone. After all, in school you are taught certain things as best practices and the bloggers you look up to take those ideas as read. But that world is invisible to many "average" developers, and even those who know about it may not feel it is as important as you do. However, simply knowing that you're not crazy, that other people encounter brick walls when they want to implement all these good things, will help you keep your sanity.
This is not to say that you should lose your drive: don't. My completely made-up estimate is that maybe 25% of developers really have it. Eventually, you will find a place in life where the drive works for you rather than frustrating you, and when you do, it will be rewarding in a way those 75% of developers may never experience (this may or may not be financial rewards).Stay positive. The very fact that you posted the question indicates that you know that there's a risk of getting mired in negative thoughts as your frustration eats away at you. If you find this happening, find ways to turn your thoughts to positive things. Go for a walk or listen to some happy music while you work. Really dig into what you are doing and block out the things that others are doing that frustrate you.
One thing that will help you stay positive is to avoid ascribing motives to others. All you know is that your frustrating coworkers don't want what you want them to want. Let them worry about why. Stop thinking even that they are unmotivated. They may be very motivated, but in ways that you don't care about.Consider the issue from other perspectives. One thing my boss tells me on a frequent basis is he doesn't even care if it's faster to do things one way vs. another way. What he really wants is to have a really good idea of exactly how long something will take. If you always do something the same way, it fulfils that goal, to most people.
Looking at the other side of things, trying a radically different approach, even if it is better practice, carries a significant risk that you might not meet deadline. From that perspective, trying approaches other than the tried and true is actually a bit unethical--you're doing something for your own mental health that may not be good for the health of the business.
Many developers and managers do not realize that good code actually makes it possible to make more reliable estimates. However, since you are only two years out of school, consider the possibility that you may not yet be ready to write that kind of code and letting you spend the time learning it could cause the company to miss some key deadlines, even if it's great for you.Work for change. Put some skin in the game, and take some of your personal time to put together a demo of the techniques that you feel should be put into place. When you make your pitch, be really careful not to say anything that sounds like a criticism of any person, and try to avoid saying "this tehcnique is bad." Instead say "I think if we did X, it would save us 30% or more of the time that we take to do task Y compared to what we're doing now." Stick to this non-critical, non-accusatory strategy even if you're asked leading questions like "But I thought we already were using best practices. Why aren't we doing this?" I followed this strategy, and I wound up getting the green light to rewrite our entire codebase.
By doing this, you might be able to put enough of a prototype out there to demonstrate that, just because you're not the most experienced member of the team, doesn't mean you can't write solid code. And you might learn enough from this that even if you're told "no," you're better able to write that type of code in the future (at this job or another).
You may be told "no," but people will remember that you took a stand. That may move the needle a bit, since you said not everyone is unmotivated. If you really believe this is the best way to do things, don't let it go, but be wise in how you press the issue. For example, when I came back from vacation and I was asked to make a change that I couldn't make because the site had been changed in ways that I had no way to know about, I pointed out to my boss that if the site had been under version control, I could have looked in the log and just seen what happened. But I would not have made that comment in front of other employees. These types of comments can seem snarky, so use them sparingly and only in one-on-one conversation. The odds someone will think they are snarky goes up exponentially based on the audience size.Build support. Consciously cultivate your "experienced and really smart" colleagues. Go to lunch together and discuss what's bugging you (in a positive way like "I had this idea..."). If they know what you think and you know what they think, when you're in meetings it is very likely that they will naturally join their voices to yours or vice versa. In fact, you should seek out opportunities to support anyone who is doing anything like offering a best practice idea, whether you previously knew this person was interested in best practice or not.
After you have built a good base among the likeminded developers, see if you can cultivate the ones you don't see as motivated. For one thing, they might surprise you. For another, they're less likely to out-and-out block you if you have a personal friendship.Realize this job is not your life, and may not be your future. You are not stuck in this job, but while you are at it, milk it for everything you can in terms of what you can learn. Maybe they will never appreciate the fire you bring to the job. That's ok--learning how to live in a job that doesn't "get" you is a valuable skill. But once you feel that you're ready to spread your wings, if you see a better opportunity, go for it. Thinking of the job as just what's going on "right now," rather than "how it will be forever" can change your attitude a lot.
Give it time. I once had a boss (who was on the verge of retiring) who told me "Amy, you don't have to get so angry. Just do what you do and eventually people will start to realize you're right a lot." It takes time to build cred, and teams don't change overnight just because you point out that they should. Give your ideas time to sink in and keep plugging, and maybe in time you'll look up and realize that things have changed a lot, for the better, in less time than you were afraid of. This happened to me :).
I think there are several things you can do to stay motivated.
First, realize you are not alone. Look around this forum. There are actually many questions that are similar to yours, although most are less direct. I've actually had the experience of being hired because I knew best practices, but wasn't allowed to implement best practices very much at all.
I think that it's easy to form a world-view where you imagine your conception of excellence is important to everyone. After all, in school you are taught certain things as best practices and the bloggers you look up to take those ideas as read. But that world is invisible to many "average" developers, and even those who know about it may not feel it is as important as you do. However, simply knowing that you're not crazy, that other people encounter brick walls when they want to implement all these good things, will help you keep your sanity.
This is not to say that you should lose your drive: don't. My completely made-up estimate is that maybe 25% of developers really have it. Eventually, you will find a place in life where the drive works for you rather than frustrating you, and when you do, it will be rewarding in a way those 75% of developers may never experience (this may or may not be financial rewards).Stay positive. The very fact that you posted the question indicates that you know that there's a risk of getting mired in negative thoughts as your frustration eats away at you. If you find this happening, find ways to turn your thoughts to positive things. Go for a walk or listen to some happy music while you work. Really dig into what you are doing and block out the things that others are doing that frustrate you.
One thing that will help you stay positive is to avoid ascribing motives to others. All you know is that your frustrating coworkers don't want what you want them to want. Let them worry about why. Stop thinking even that they are unmotivated. They may be very motivated, but in ways that you don't care about.Consider the issue from other perspectives. One thing my boss tells me on a frequent basis is he doesn't even care if it's faster to do things one way vs. another way. What he really wants is to have a really good idea of exactly how long something will take. If you always do something the same way, it fulfils that goal, to most people.
Looking at the other side of things, trying a radically different approach, even if it is better practice, carries a significant risk that you might not meet deadline. From that perspective, trying approaches other than the tried and true is actually a bit unethical--you're doing something for your own mental health that may not be good for the health of the business.
Many developers and managers do not realize that good code actually makes it possible to make more reliable estimates. However, since you are only two years out of school, consider the possibility that you may not yet be ready to write that kind of code and letting you spend the time learning it could cause the company to miss some key deadlines, even if it's great for you.Work for change. Put some skin in the game, and take some of your personal time to put together a demo of the techniques that you feel should be put into place. When you make your pitch, be really careful not to say anything that sounds like a criticism of any person, and try to avoid saying "this tehcnique is bad." Instead say "I think if we did X, it would save us 30% or more of the time that we take to do task Y compared to what we're doing now." Stick to this non-critical, non-accusatory strategy even if you're asked leading questions like "But I thought we already were using best practices. Why aren't we doing this?" I followed this strategy, and I wound up getting the green light to rewrite our entire codebase.
By doing this, you might be able to put enough of a prototype out there to demonstrate that, just because you're not the most experienced member of the team, doesn't mean you can't write solid code. And you might learn enough from this that even if you're told "no," you're better able to write that type of code in the future (at this job or another).
You may be told "no," but people will remember that you took a stand. That may move the needle a bit, since you said not everyone is unmotivated. If you really believe this is the best way to do things, don't let it go, but be wise in how you press the issue. For example, when I came back from vacation and I was asked to make a change that I couldn't make because the site had been changed in ways that I had no way to know about, I pointed out to my boss that if the site had been under version control, I could have looked in the log and just seen what happened. But I would not have made that comment in front of other employees. These types of comments can seem snarky, so use them sparingly and only in one-on-one conversation. The odds someone will think they are snarky goes up exponentially based on the audience size.Build support. Consciously cultivate your "experienced and really smart" colleagues. Go to lunch together and discuss what's bugging you (in a positive way like "I had this idea..."). If they know what you think and you know what they think, when you're in meetings it is very likely that they will naturally join their voices to yours or vice versa. In fact, you should seek out opportunities to support anyone who is doing anything like offering a best practice idea, whether you previously knew this person was interested in best practice or not.
After you have built a good base among the likeminded developers, see if you can cultivate the ones you don't see as motivated. For one thing, they might surprise you. For another, they're less likely to out-and-out block you if you have a personal friendship.Realize this job is not your life, and may not be your future. You are not stuck in this job, but while you are at it, milk it for everything you can in terms of what you can learn. Maybe they will never appreciate the fire you bring to the job. That's ok--learning how to live in a job that doesn't "get" you is a valuable skill. But once you feel that you're ready to spread your wings, if you see a better opportunity, go for it. Thinking of the job as just what's going on "right now," rather than "how it will be forever" can change your attitude a lot.
Give it time. I once had a boss (who was on the verge of retiring) who told me "Amy, you don't have to get so angry. Just do what you do and eventually people will start to realize you're right a lot." It takes time to build cred, and teams don't change overnight just because you point out that they should. Give your ideas time to sink in and keep plugging, and maybe in time you'll look up and realize that things have changed a lot, for the better, in less time than you were afraid of. This happened to me :).
edited Apr 13 '17 at 12:48
Community♦
1
1
answered Feb 16 '13 at 3:50
Amy Blankenship
7,13711836
7,13711836
add a comment |Â
add a comment |Â
up vote
0
down vote
When given a problem, they would choose the first available option or they would just look at an existing solution and copy-paste the same. And such colleagues are actually at positions senior to me.
........
I feel bad (and also sad) when something is done in a way when I know a better way to do the same exists
Your colleagues may be in a position senior to you because they're able to get stuff done quickly, and effectively.
When you say that a "better way" exists, are you saying that the way it was done was not elegant, not "pretty", and that you had a slicker way to accomplish the same? Or are you saying that your colleagues are putting out dangerous, un-secure code, or code that will be terribly difficult to maintain and scale?
If the first is the case, then welcome to the real world. Companies want stuff done quickly, since time is money.
If you're dealing with the second, then it sounds like you're in a terrible company with poor management. Suck it up, learn as much as you can, then move on to a better opportunity when you have the chance.
add a comment |Â
up vote
0
down vote
When given a problem, they would choose the first available option or they would just look at an existing solution and copy-paste the same. And such colleagues are actually at positions senior to me.
........
I feel bad (and also sad) when something is done in a way when I know a better way to do the same exists
Your colleagues may be in a position senior to you because they're able to get stuff done quickly, and effectively.
When you say that a "better way" exists, are you saying that the way it was done was not elegant, not "pretty", and that you had a slicker way to accomplish the same? Or are you saying that your colleagues are putting out dangerous, un-secure code, or code that will be terribly difficult to maintain and scale?
If the first is the case, then welcome to the real world. Companies want stuff done quickly, since time is money.
If you're dealing with the second, then it sounds like you're in a terrible company with poor management. Suck it up, learn as much as you can, then move on to a better opportunity when you have the chance.
add a comment |Â
up vote
0
down vote
up vote
0
down vote
When given a problem, they would choose the first available option or they would just look at an existing solution and copy-paste the same. And such colleagues are actually at positions senior to me.
........
I feel bad (and also sad) when something is done in a way when I know a better way to do the same exists
Your colleagues may be in a position senior to you because they're able to get stuff done quickly, and effectively.
When you say that a "better way" exists, are you saying that the way it was done was not elegant, not "pretty", and that you had a slicker way to accomplish the same? Or are you saying that your colleagues are putting out dangerous, un-secure code, or code that will be terribly difficult to maintain and scale?
If the first is the case, then welcome to the real world. Companies want stuff done quickly, since time is money.
If you're dealing with the second, then it sounds like you're in a terrible company with poor management. Suck it up, learn as much as you can, then move on to a better opportunity when you have the chance.
When given a problem, they would choose the first available option or they would just look at an existing solution and copy-paste the same. And such colleagues are actually at positions senior to me.
........
I feel bad (and also sad) when something is done in a way when I know a better way to do the same exists
Your colleagues may be in a position senior to you because they're able to get stuff done quickly, and effectively.
When you say that a "better way" exists, are you saying that the way it was done was not elegant, not "pretty", and that you had a slicker way to accomplish the same? Or are you saying that your colleagues are putting out dangerous, un-secure code, or code that will be terribly difficult to maintain and scale?
If the first is the case, then welcome to the real world. Companies want stuff done quickly, since time is money.
If you're dealing with the second, then it sounds like you're in a terrible company with poor management. Suck it up, learn as much as you can, then move on to a better opportunity when you have the chance.
answered Feb 15 '13 at 23:46
Adam Rackis
1,4891116
1,4891116
add a comment |Â
add a comment |Â
up vote
0
down vote
I have no idea how CS degrees work where you're from, but from what I've seen, they have very little to do with the work of a software engineer. Academia is famously shielded from the real world.
The hard part is striking a balance between some untangible ideal and the "it just works" solution. Either of the extremes work, in fact - in some environments. If you're making contract end-user stuff with no prospects at maintenance, "just getting it done" is a valid philosophy. When you're writing Shuttle software, you've got a lot more time to polish.
When you're trying to change the approach of the people around you, make sure to actually be sure about the benefits. Build up the pro's and con's, estimate the costs associated with "bad solutions", and the costs associated with "proper code" - neither is free. If you're lucky, the people around you understand opportunity costs - that makes it much easier to go towards better architecture, better code. If the code takes twice as long to write, but is half as much work to maintain and extend, you want to show that that cost actually pays back at some point, with reasonable certainty.
Customer satisfaction is also a hugely important factor. If the choice is between better code and better user experience, UX always wins, and it should. Again, the biggest tipping factor is when better code leads to better UX in the future - will the impact of better code be enough to make it cheaper in the end? Good code is often an investment, not something of value out of the box; rarely will you find an opportunity when good code gives better efficiency on the original task (note that I'm talking about "bad" code produced by good programmers - if your programmers are simply bad and sloppy, you're out of luck); the payback usually comes further down the road, if at all.
People have trouble thinking about investments. Get some numbers. It can be very helpful if you can actually gather some data from the past - when you suggest some architectural or code quality change, write it down. When the time comes and your suggestion would save time or improve customer satisfaction - write it down. When you have enough, go to your managers, seniors, whoever - it's easier to argue when you've got "hard" data in your hands.
The reverse applies too. Don't assume that "better" code is automatically better. I've seen many cases where the programmers were losing way too much time working out things that didn't matter - on a test application that was only there for one scenario and thrown away, elsewhere creating an architecture that was overly complicated and in the end inhibited further development.
Perfect is rarely good. If your backlog isn't full of (minor) bugs and feature requests that you simply don't have the time and resources to fix, you're probably doing something wrong, and your competition is gaining on you.
I'm usually thinking in terms of time or money. Translating things to money helps a lot in cost-benefit calculations. This took me a bit more work, and I got some experience from it. How much would I pay for that knowledge, was it worth it? It will save me some time down the road - is it enough? What will be the cost if I don't do it that way and it will turn out to be a bad decision down the road? It's crucial to know how much time was spent fixing bugs on the original task, otherwise the perception gets extremely skewed. If something took me 4 hours, just as estimated, but then I spent 20 hours fixing the bugs, it has to be visible that my estimate was way off.
It takes a lot of pushing if you're "the only one". But it can be done, you can move to better practices, better code, better software. Just make sure that in the end, it's actually better in some measurable way.
add a comment |Â
up vote
0
down vote
I have no idea how CS degrees work where you're from, but from what I've seen, they have very little to do with the work of a software engineer. Academia is famously shielded from the real world.
The hard part is striking a balance between some untangible ideal and the "it just works" solution. Either of the extremes work, in fact - in some environments. If you're making contract end-user stuff with no prospects at maintenance, "just getting it done" is a valid philosophy. When you're writing Shuttle software, you've got a lot more time to polish.
When you're trying to change the approach of the people around you, make sure to actually be sure about the benefits. Build up the pro's and con's, estimate the costs associated with "bad solutions", and the costs associated with "proper code" - neither is free. If you're lucky, the people around you understand opportunity costs - that makes it much easier to go towards better architecture, better code. If the code takes twice as long to write, but is half as much work to maintain and extend, you want to show that that cost actually pays back at some point, with reasonable certainty.
Customer satisfaction is also a hugely important factor. If the choice is between better code and better user experience, UX always wins, and it should. Again, the biggest tipping factor is when better code leads to better UX in the future - will the impact of better code be enough to make it cheaper in the end? Good code is often an investment, not something of value out of the box; rarely will you find an opportunity when good code gives better efficiency on the original task (note that I'm talking about "bad" code produced by good programmers - if your programmers are simply bad and sloppy, you're out of luck); the payback usually comes further down the road, if at all.
People have trouble thinking about investments. Get some numbers. It can be very helpful if you can actually gather some data from the past - when you suggest some architectural or code quality change, write it down. When the time comes and your suggestion would save time or improve customer satisfaction - write it down. When you have enough, go to your managers, seniors, whoever - it's easier to argue when you've got "hard" data in your hands.
The reverse applies too. Don't assume that "better" code is automatically better. I've seen many cases where the programmers were losing way too much time working out things that didn't matter - on a test application that was only there for one scenario and thrown away, elsewhere creating an architecture that was overly complicated and in the end inhibited further development.
Perfect is rarely good. If your backlog isn't full of (minor) bugs and feature requests that you simply don't have the time and resources to fix, you're probably doing something wrong, and your competition is gaining on you.
I'm usually thinking in terms of time or money. Translating things to money helps a lot in cost-benefit calculations. This took me a bit more work, and I got some experience from it. How much would I pay for that knowledge, was it worth it? It will save me some time down the road - is it enough? What will be the cost if I don't do it that way and it will turn out to be a bad decision down the road? It's crucial to know how much time was spent fixing bugs on the original task, otherwise the perception gets extremely skewed. If something took me 4 hours, just as estimated, but then I spent 20 hours fixing the bugs, it has to be visible that my estimate was way off.
It takes a lot of pushing if you're "the only one". But it can be done, you can move to better practices, better code, better software. Just make sure that in the end, it's actually better in some measurable way.
add a comment |Â
up vote
0
down vote
up vote
0
down vote
I have no idea how CS degrees work where you're from, but from what I've seen, they have very little to do with the work of a software engineer. Academia is famously shielded from the real world.
The hard part is striking a balance between some untangible ideal and the "it just works" solution. Either of the extremes work, in fact - in some environments. If you're making contract end-user stuff with no prospects at maintenance, "just getting it done" is a valid philosophy. When you're writing Shuttle software, you've got a lot more time to polish.
When you're trying to change the approach of the people around you, make sure to actually be sure about the benefits. Build up the pro's and con's, estimate the costs associated with "bad solutions", and the costs associated with "proper code" - neither is free. If you're lucky, the people around you understand opportunity costs - that makes it much easier to go towards better architecture, better code. If the code takes twice as long to write, but is half as much work to maintain and extend, you want to show that that cost actually pays back at some point, with reasonable certainty.
Customer satisfaction is also a hugely important factor. If the choice is between better code and better user experience, UX always wins, and it should. Again, the biggest tipping factor is when better code leads to better UX in the future - will the impact of better code be enough to make it cheaper in the end? Good code is often an investment, not something of value out of the box; rarely will you find an opportunity when good code gives better efficiency on the original task (note that I'm talking about "bad" code produced by good programmers - if your programmers are simply bad and sloppy, you're out of luck); the payback usually comes further down the road, if at all.
People have trouble thinking about investments. Get some numbers. It can be very helpful if you can actually gather some data from the past - when you suggest some architectural or code quality change, write it down. When the time comes and your suggestion would save time or improve customer satisfaction - write it down. When you have enough, go to your managers, seniors, whoever - it's easier to argue when you've got "hard" data in your hands.
The reverse applies too. Don't assume that "better" code is automatically better. I've seen many cases where the programmers were losing way too much time working out things that didn't matter - on a test application that was only there for one scenario and thrown away, elsewhere creating an architecture that was overly complicated and in the end inhibited further development.
Perfect is rarely good. If your backlog isn't full of (minor) bugs and feature requests that you simply don't have the time and resources to fix, you're probably doing something wrong, and your competition is gaining on you.
I'm usually thinking in terms of time or money. Translating things to money helps a lot in cost-benefit calculations. This took me a bit more work, and I got some experience from it. How much would I pay for that knowledge, was it worth it? It will save me some time down the road - is it enough? What will be the cost if I don't do it that way and it will turn out to be a bad decision down the road? It's crucial to know how much time was spent fixing bugs on the original task, otherwise the perception gets extremely skewed. If something took me 4 hours, just as estimated, but then I spent 20 hours fixing the bugs, it has to be visible that my estimate was way off.
It takes a lot of pushing if you're "the only one". But it can be done, you can move to better practices, better code, better software. Just make sure that in the end, it's actually better in some measurable way.
I have no idea how CS degrees work where you're from, but from what I've seen, they have very little to do with the work of a software engineer. Academia is famously shielded from the real world.
The hard part is striking a balance between some untangible ideal and the "it just works" solution. Either of the extremes work, in fact - in some environments. If you're making contract end-user stuff with no prospects at maintenance, "just getting it done" is a valid philosophy. When you're writing Shuttle software, you've got a lot more time to polish.
When you're trying to change the approach of the people around you, make sure to actually be sure about the benefits. Build up the pro's and con's, estimate the costs associated with "bad solutions", and the costs associated with "proper code" - neither is free. If you're lucky, the people around you understand opportunity costs - that makes it much easier to go towards better architecture, better code. If the code takes twice as long to write, but is half as much work to maintain and extend, you want to show that that cost actually pays back at some point, with reasonable certainty.
Customer satisfaction is also a hugely important factor. If the choice is between better code and better user experience, UX always wins, and it should. Again, the biggest tipping factor is when better code leads to better UX in the future - will the impact of better code be enough to make it cheaper in the end? Good code is often an investment, not something of value out of the box; rarely will you find an opportunity when good code gives better efficiency on the original task (note that I'm talking about "bad" code produced by good programmers - if your programmers are simply bad and sloppy, you're out of luck); the payback usually comes further down the road, if at all.
People have trouble thinking about investments. Get some numbers. It can be very helpful if you can actually gather some data from the past - when you suggest some architectural or code quality change, write it down. When the time comes and your suggestion would save time or improve customer satisfaction - write it down. When you have enough, go to your managers, seniors, whoever - it's easier to argue when you've got "hard" data in your hands.
The reverse applies too. Don't assume that "better" code is automatically better. I've seen many cases where the programmers were losing way too much time working out things that didn't matter - on a test application that was only there for one scenario and thrown away, elsewhere creating an architecture that was overly complicated and in the end inhibited further development.
Perfect is rarely good. If your backlog isn't full of (minor) bugs and feature requests that you simply don't have the time and resources to fix, you're probably doing something wrong, and your competition is gaining on you.
I'm usually thinking in terms of time or money. Translating things to money helps a lot in cost-benefit calculations. This took me a bit more work, and I got some experience from it. How much would I pay for that knowledge, was it worth it? It will save me some time down the road - is it enough? What will be the cost if I don't do it that way and it will turn out to be a bad decision down the road? It's crucial to know how much time was spent fixing bugs on the original task, otherwise the perception gets extremely skewed. If something took me 4 hours, just as estimated, but then I spent 20 hours fixing the bugs, it has to be visible that my estimate was way off.
It takes a lot of pushing if you're "the only one". But it can be done, you can move to better practices, better code, better software. Just make sure that in the end, it's actually better in some measurable way.
answered Jun 6 '14 at 14:31
Luaan
10124
10124
add a comment |Â
add a comment |Â
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
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fworkplace.stackexchange.com%2fquestions%2f9703%2fhow-to-stay-motivated-when-it-feels-that-senior-colleagues-arent%23new-answer', 'question_page');
);
Post as a guest
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
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
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
3
Never write what you can steal because time is money. Also, code reuse is good if the code is good but I can understand if they are copying bad solutions just to save time. Are you sure that putting extra effort into the task is worth it? If it is a small job it might not be that big of a deal. There is always the temptation to redo someone else's work because you don't like it, it took me a while to get over that urge.
– CincinnatiProgrammer
Feb 14 '13 at 18:35
13
Hate to be blunt, but it's likely the reason they are senior to you is they understand the purpose of business is to make money - not make pretty code or pretty processes. My answer here probably is one of the best ways you can keep yourself motivated.
– Elysian Fields♦
Feb 14 '13 at 19:14
7
@sunny doing business properly is getting results for lower cost. This often (especially in software) can come at the cost of crappy code, bad architecture, poor API utilization, or a whole host of other problems (from "pretty/good software" perspectives) which the customer never sees.
– Elysian Fields♦
Feb 14 '13 at 19:38
7
@Sunny - no surprise there. they teach theory in college, not practice.
– IDrinkandIKnowThings
Feb 14 '13 at 20:19
4
Voted to reopen. I think most people who are passionate about the tech industry have worked in a situation where they asked themselves this question. I often wonder if the people who are on the "other side" of this question are the ones who got beat down before they found an answer that brought them peace.
– Amy Blankenship
Feb 15 '13 at 0:21