i-Technology Viewpoint: We Need Not More Frameworks, But Better Programmers
It's no secret that I've been outspoken about not liking frameworks for quite some time now. The truth is, I believe that frameworks have a lot to offer. The most significant benefit that organizations stand to gain from using frameworks is a standardized way to code and an environment that is generally more conducive to allowing multiple developers to work on a project at the same time. If frameworks help to standardize how things are done and make it easier for many developers to work on a project, why have I been vocal about not liking them? Am I just trying to create controversy?
Reader Feedback : Page 1 of 1
#14
Dennis Muzza commented on the 11 Dec 2006
You shouldn't lose sight of the ultimate goal, which is producing good, robust, scalable systems. If this can be successfully accomplished by cheap, inexperienced programmers relying on a framework that does pretty much everything for them, more power to the business that employs them.
The problem I see with frameworks is that few of them are really good and widely usable, and those that are still call for a lot of custom coding which requires good developers. Oftentimes companies spend millions to develop frameworks loaded with every possible feature, and then it becomes the proverbial hammer to which everything looks like a nail. People begin using it because it's there and a lot was invested in creating it, not because it really solves a problem.
#13
Serge Bureau commented on the 11 Apr 2006
Sorry but I feel the opposite.
Framework is the reason for bad programmers. EJB's and Struts for example are awful (I have not look at EJB 3)
Companies are pushing people to use those framework that are big and inflexible.
So while thre certainly is bad programmer's, I have still to see a good framework ?
#12
jim commented on the 4 Apr 2006
Poor developers using frameworks as a crutch is a symptom of them being poor developers in the first place. IMO there should be licensing for software engineers just like every other engineering profession. There are way to many script kiddies out there who have learned one framework and call themselves developers - There should be a bare minimum set of abilities you can count on a develper having, and so many don't. I can't tell you the number of "developers" I've dealt with who have degrees in philosophy or english or phys ed, who have no idea what a data structure is, but have mastered basic cold fusion, so they're now "senior programmers". Until we set a baseline bar that everyone has to hurdle to call themselves a software engineer, our industry will continue to be plauged by these frauds.
#11
Ananthalakshmi commented on the 3 Apr 2006
Hi, Your view may be true in the context of ColdFusion Development. But, in real application development scenarios in languages like Java, .NET, etc and in building enterprise applications where the problem solving methodoligies and the implementation needs reusable and prooved strategies for recurring problems(for ex, page iteration, adopter, MVC architectural patterns, etc) instead of developing the solution from scratch for each application that is being developed in the organization, instead to reuse existing components, build reusable services, adopt proven strategies(design patterns, etc) will certainly improve the productivity of the developer and also to build quality, reliable and scalable applications which is the most need of every application that we develop.
Yes, it is the responsibility of the developer to understand the underlying technology, logic that the framework uses and on which it is built on before started using it or understanding it while working on the project based on the framework.
In real world, frameworks make life simple and more simply makes application development more easier instead of building it from scratch.
Thanks.
#10
Jos Warmer commented on the 3 Apr 2006
You want controverse? Ok, I will help :-). I think you are absolutely wrong. The reality is that about 10% of the programmers is good, 10% is bad and the 80% remaining is somewhere in between (and do not have it in them to become good programmers). As with many professions my guess is that this will have a normal distribution.
Since the majority of the programmer is not excellent and never will be, we need ways of making mediocre programmers productive. Using a framework is one approach (although I have seen frameworks that are too complex for this). The main issue is that these programmers need less freedom and more prefabicated stuff to work with. This might mean using frameworks, using existing components, using MDA or DSL's, etc. etc. The challenge for those that are in the 10% good group is to find ways to help make the majority of less good programmers productive.
PS: I fully agree that we need more good programmers, I just do not agree that this will ever solve our problems. There simply isn't enough potential in the world.
#9
Mark Walker commented on the 3 Apr 2006
It's about time somebody said it. The multitude of frameworks, "evil" wizards and other sugar has led to a generation of inept programmers. I'm all in favour of good tools, but not a substitute for good people.
#8
Just some programmer commented on the 3 Apr 2006
Any idiot can write code a computer can understand. Frameworks, design patterns, OOP, and high level languages are all just strategies to mitigate the problem size / complexity curve - a primary goal of competent programmers. Why has the science of software development continued to inch forward when it should have leapt? Why is most "OO" software still written procedurally (and with less skill than procedural code written in 1979)? A lack of competent programmers is certainly at the heart of it but you have to look further than that. Most business stakeholders have no appreciation for what we do. They simply don't care how the work gets done. In fact, doing things 'right' (refactoring, writing automated tests, etc.) can get you in hot water. As a result, there's little motivation to improve and grow in skill. Managers focus on short term goals that cost big in the long run. Shops that value excellence in execution and invest in their employees produce much higher quality software - and programmers.
#7
Wayne Cannon commented on the 1 Apr 2006
While I agree with your general sentiments, reality is that not every employer can afford to spend $100-150K for "good" programmers with the desired insight and depth of understanding. Looking at the market right now, there are lots of positions only willing to pay $40-80K. For most of them, it's this level or none at all -- and I would suggest that customers and our economy are better off with the current situation, even if some of the solutions are a little rough under the covers.
I've been developing software professionally for 40 years and have been fortunate to have been at the state of the art almost that entire time. The same issues occur in many other industries. Designers of electronics used to understand everything to the component level, but the sophistication, speeds, and associated complexity have increased to the point that only a few now have that level of insight. Many now use high-level (LSI) components without thorough insight -- and occasionally it results in glitches or poor maintainability. I say that's progress, and that the important point is to design architectures (and frameworks) that can guide those that flesh out implementations into better and more maintainable results -- and that "insightful programmers" should definitely be deployed for such architectural design.
#6
Wayne Cannon commented on the 1 Apr 2006
While I agree with your general sentiments, reality is that not every employer can afford to spend $100-150K for "good" programmers with the desired insight and depth of understanding. Looking at the market right now, there are lots of positions only willing to pay $40-80K. For most of them, it's this level or none at all -- and I would suggest that customers and our economy are better off with the current situation, even if some of the solutions are a little rough under the covers.
I've been developing software professionally for 40 years and have been fortunate to have been at the state of the art almost that entire time. The same issues occur in many other industries. Designers of electronics used to understand everything to the component level, but the sophistication, speeds, and associated complexity have increased to the point that only a few now have that level of insight. Many now use high-level (LSI) components without thorough insight -- and occasionally it results in glitches or poor maintainability. I say that's progress, and that the important point is to design architectures (and frameworks) that can guide those that flesh out implementations into better and more maintainable results -- and that "insightful programmers" should definitely be deployed for such architectural design.
#5
Manjunath Kustagi commented on the 31 Mar 2006
I absolutely agree, one sees many sundry god-knows who writing programs in industry nowadays
Ditto on Design Patterns being an absolute hogwash, but I disgree with your dislike of OOP.. I think it's based on a sound basis if comprehended and used properly
#4
Sys-Con Australia News Desk commented on the 29 Mar 2006
It's no secret that I've been outspoken about not liking frameworks for quite some time now. The truth is, I believe that frameworks have a lot to offer. The most significant benefit that organizations stand to gain from using frameworks is a standardized way to code and an environment that is generally more conducive to allowing multiple developers to work on a project at the same time. If frameworks help to standardize how things are done and make it easier for many developers to work on a project, why have I been vocal about not liking them? Am I just trying to create controversy?
#3
Kevin Roche commented on the 29 Mar 2006
Simon,
I know we will never agree on this. What would you do with all the guys who are never going to be able to develop a sensible architechture that will be suitable for each application. Would you ban them from programming altogether?
Most people are not as clever as you. Without the help of a framework their work would be much less useful.
#2
Brian Cassell commented on the 15 Mar 2006
I agree with your bold and controversial comments, and will add a few as well.
Frameworks provide a neat way of chopping things into millions of little pieces with the assumption of reusability and granularity. Yes, you can reuse an include file that contains an HTML open tag on every page you create, but what is the sense, what is saved? There seems to be some greater value achieved by "simplifying" things to the smallest element in a framework based implementation. I prefer to open a page and be able to read from top to bottom to see what the heck is happening, rather than looking at the 10 included files that just overly complicate what probably could have been right on one page.
Separation between presentation and content is another popular idea that I disagree with. Presentation is nothing without content, and content is nothing without presentation. They add value to each other. What good is an over engineered application that supposedly can be updated independently of the interface if the front-end design sucks and has no integrated relationship with the content? I prefer to begin with a graphic design interface including content, and then work the code hooks into it, respecting the interface as designed, yet adding the desired functionality.
What do you think?
#1
Edward Trudeau commented on the 15 Mar 2006
I don't know, Simon...I kind of want to say, "Waah." Some developers aren't where they "should be" after two years of development using frameworks; some are throwing around design pattern names without really "getting it." I'm just not feeling the pain. Are they forcing salaries down? Are they introducing security risks? Are they devaluing resumes with their empty-calorie experience? Are they giving CF a bad name? Are you offended on principle?
All of the above are probably true to a certain extent, but it seems like exhorting developers to grasp the basics, explaining design patterns more carefully, and building an authentic "Object Think" mentality is the more profitable route.
Historically, the technocracy has enjoyed privilege precisely because of the difficulty of grasping the technology. This has inspired a kind of obscurantism that I see in my colleagues; keep it complex so that I can keep my job, I can demand high salaries, I will get the ego boost of being the go-to guy. Talk technobabble to the management - our way to "stick it to the man." Frankly, I've been excited and encouraged by the free sharing of information that I've found in the CF community. I get the impression that people like you, Ben, Ray, Joe, and Sean honestly want all of us to become great programmers and revolutionize the world with fun, useful, productivity-enhancing applications. So I'd rather see the middle way between controversy and silence: dialogue.
Paul Hands wrote: O'Gara
continues to be an
abject, putrid idiot.
Why publish that drivel?
To quote Pauli, "this is
not even wrong". It's
also an egregious
conflict of interest.
Rob wrote: Sorry Julien,
You're wrong about Web
3.0. However, you have
described some nice Web 2
tools.
That's all Web 2.0
is...tools! Tools to help
us connect people to
people.
What's Web 3.0?
Organizing people and
using the tools of Web
2.0 to create a
workforce.
http://web...
Raj Kumar Kundu wrote:
This content is very
useful for all those
people who are thinking
about
internationalization of
J2EE/ Web Based
applications. It explains
and points out the areas
which should be rather
can be considered for
this activity. This can
help people start
t...
Teja wrote: Excellent way
to describe weblogic 9.x
product features and at
the same time much into
technical explanation
gives over view to all
dev and admin to know
more abt it .
Thanks again .
Teja
SUBSCRIBE TO THE WORLD'S MOST POWERFUL NEWSLETTERS
Help Wanted: SYS-CON Media is looking for i-technology reporters, and journalists. Please apply to reporters(at)sys-con.com. We are also seeking online advertising sales representatives with proven track record. Please apply to careers(at)sys-con.com.