 2007 West |
|
GOLD SPONSORS:
|
Active Endpoints Your SOA Needs BPEL for Orchestration
|
BEA Virtualized SOA: Adaptive Infrastructure for Demanding Applications
|
Nexaweb Overcoming Bandwidth Challenges with Nexaweb
|
TIBCO What is Service Virtualization?
|
|
SILVER SPONSORS:
|
WSO2 Using Web Services Technologies and FOSS Solutions
|
|
Click For 2007 East Event Webcasts
|
|
TOP THREE LINKS YOU MUST CLICK ON
Editorial
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. Edward |
YOUR FEEDBACK  | Is Sun Looking to Replace
CEO Jonathan Schwartz? By Maureen O'Gara Brigdson Smith wrote:
remember, Eric Schmidt
was Schwartz's first boss
at Sun - something tells
me if he left Sun, it'd
take four minutes for him
to end up to Google. |  | What Does the Future Hold
for the Java Language? By Joe Winchester Tommy wrote: I simply do
not agree on many parts:
- .NET has a lot of
traction
- you can
certainly know well (and
master) more than one
language. If you cannot
master more than one
language, this could
potentially be one of
your limits.
- Java is not a perfect
language
- It is ea... |  | i-Technology Opinion: Why
Use Extreme Programming? By Troy Holmes James Nwaba wrote: This
is a nice article - very
straight froward, easy to
understand.However, there
was no mention of any
organization that have
implemented XP.
The author said, "Many of
the concepts found in
this lightweight method
of development have been
implemented into the ... |  | iPhone Office: 100 Ways
to Turn Your Device into
the Ultimate Productivity
Tool By Jessica Merritt QueZZtion wrote: Can the
iPhone really work as a
multimedia remote for
iTunes or even a desktop? |  | DoJa in NTT DoCoMo Phones By Zev Blut Venkat wrote: Excellent
explanation. It will be
helpful if it was in
pictorial form ie with
the emulator images. Can
u please send me the
I-mode to I appli
communication and a brief
explanatioj about the
architecture.Thanks in
advance. |
SUBSCRIBE TO THE WORLD'S MOST POWERFUL NEWSLETTERS
|
SYS-CON FEATURED WHITEPAPERS  | Saving Your Investment:
Transforming J2EE
applications into Web 2.0
using GWT By RIA News Desk The pressure is on to
keep pace with Web 2.0
entrants into the
marketplace. Rewriting is
expensive; | WSRP Really Works! - Part
2 By Matt Silver A standard from OASIS
called Web Services for
Remote Portlets (WSRP) is
used so portlets can be
deco | Adobe's Kevin Lynch and
Microsoft's Scott Guthrie
to Keynote AJAX World RIA
Conference & Expo By RIA News Desk Two of the biggest
launches in Rich Internet
Application history took
place in 2007/2008 when
Adobe | Sun Expects Q4 Earnings
Above Estimates By Java News Desk On Tuesday evening Sun
issued a fourth-quarter
guidance range largely
above analysts'
estimates. The | Virtualization Conference
Keynote Webcast Live on
SYS-CON.TV By James Hamilton Brian Stevens, the Chief
Technology Officer and
Vice President of
Engineering of Red Hat,
delivered | The Beauty of JavaScript By RIA News Desk JavaScript is one of the
most interesting and
misunderstood programming
languages in common use
toda | JavaScript: The Good
Parts By RIA News Desk JavaScript is a language
with more than its share
of bad parts. It went
from non-existence to
global | Use JavaScript 2 Today
with OpenLaszlo By RIA News Desk JavaScript 2 is becoming
increasingly important.
Learn how to take
advantage of JavaScript 2
while s | Server-Side JavaScript -
All the Cool Kids Are
Doing It! By RIA News Desk In this session that no
developer who uses
JavaScript or
ActionScript will want to
miss, delegates w | AJAX with jQuery By RIA News Desk jQuery is a rapidly
growing, popular
JavaScript library. Its
powerful and modular
architecture, whic | Why the Web Dinosaurs
Died By Jonas Jacobi; John Fallows; Ric Smith; Brian Albers A fast-moving Comet is
about to impact the
Internet. When it hits,
it will wipe away the
architectur | Sun Achieves Land Speed
Record: 1M Messages Per
Second By Java News Desk Algorithmic trading
continues to drive the
quest for greater speed
and lower latency in the
capital | AJAX and RIA Technology
Will Be Free for All: Sun
CEO By Java News 'Java's always been a RIA
platform - before the
world really wanted one,'
claimed Sun's CEO
Jonathan | Quest Software's JProbe
Now Available as Eclipse
Plug-In By Eclipse News Desk Quest Software announced
the latest release of its
Java profiler, JProbe
8.0, which is now offered
a | What Does the Future Hold
for the Java Language? By Joe Winchester Before Java I was a
Smalltalk guy. I remember
switching from one
language to the other and
the tippi | White Paper: "Ensuring
Code Quality in
Multi-Threaded
Applications" By Java News Desk Today, the world of
software development is
presented with a new
challenge. To fully
leverage this n | AccuRev and Rally
Software Partner to Scale
Agile Software
Development Best
Practices By SOA World Magazine News Desk AccuRev and Rally
announced a technology
partnership that will
integrate AccuRev
software change and | MyEclipse 6.5: The Maven
Tipping Point for 1
Million Java Developers By Eclipse News Desk Genuitec announced the
availability of MyEclipse
Enterprise Workbench 6.5;
Java's most compelling ID | AccuRev Leverages Web 2.0
Technology to Extend
Process Management Reach
Across the Organization By Web 2.0 News Desk AccuRev announced a new
AJAX-based Web Interface
and a native integration
with Microsoft Windows
Exp | Voyager Offers Android,
.NET CF, Java Runtime
Support By Wireless News Desk Recursion Software
released a private beta
version of their Voyager
mobile platform, with
powerful i |
SPONSORED BY INFRAGISTICS
|