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

2008 East
PLATINUM SPONSORS:
Appcelerator
Think Fast: Accelerate AJAX Development with Appcelerator
GOLD SPONSORS:
DreamFace Interactive
The Ultimate Framework for Creating Personalized Web 2.0 Mashups
ICEsoft
AJAX and Social Computing for the Enterprise
Kaazing
Enterprise Comet: Real–Time, Real–Time, or Real–Time Web 2.0?
Nexaweb
Now Playing: Desktop Apps in the Browser!
Sun
jMaki as an AJAX Mashup Framework
POWER PANELS:
The Business Value
of RIAs
What Lies Beyond AJAX?
KEYNOTES:
Douglas Crockford
Can We Fix the Web?
Anthony Franco
2008: The Year of the RIA
Click For 2007 Event Webcasts
Zend Studio for Eclipse
In my many years of programming, almost 20 years n
BLOG-N-PLAY.COM
Another Darwin Award Wannabe
Another Darwin Award Wannabe
TOP LINKS YOU MUST CLICK ON



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

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.

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 ?

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.

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.

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.

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.

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.

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.

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.

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

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?

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.

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?

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


FEATURED WHITE PAPERS
YOUR FEEDBACK
RIM Announces BlackBerry JDE Plug-in for Eclipse
Don Babcock wrote: I love(d) mobile development with Java. Right up to the point that I found out that it was next to impossible to get apps to market through the catacombs you are required to navigate with each and every separate telecom provider out there in order to get yo...
Setting a Project Based on an Existing ANT Build File
Steve Cohen wrote: I also have this problem. It would appear that the purpose of this function is to import build files that were created by exporting an existing Eclipse java project buildfile. It is not intended to be able to import any random build.xml, which might conta...
Eclipse Runtime Project Is Born
queZZtion wrote: How does Equinox relate to RCP, RAP, Swordfish, EclipseLink and ECF?
Debugging and Profiling with Eclipse, Jetty, and Tomcat
Jan Bartel wrote: Hi Sujit, Glad to see you use Jetty. Just one thing, the maven-jetty6-plugin is now really really old. We renamed it some time ago to just the maven-jetty-plugin. The current version is jetty-6.1.7, very soon to be release jetty-6.1.8. cheers Jan
Intel Tanks; Blames Television in Part
Intel News Desk wrote: Intel's Q4 results, as good as they were, failed to impress a panicky 'the sky is falling' stock market and Intel's light Q1 forecast, which the company called 'a little bit cautious' on the US economy, sent the stock and the market down Wednesday
SUBSCRIBE TO THE WORLD'S MOST POWERFUL NEWSLETTERS

SYS-CON FEATURED WHITEPAPERS

BREAKING NEWS FROM THE WIRES
3rd International Virtualization Conference & Expo: Themes & Topics
From Application Virtualization to Xen, a round-up of the virtualization themes & topics being discu
Borland Finally Dumps CodeGear Tools Division
It's only taken Borland two years but it's finally dumped its CodeGear tools division, responsible f
AJAX World - Skyway Software Announces RIA Developer Contest
According to Sean Walsh, President and CEO of Skyway Software, 'Our Skyway Community is thriving and
Skyway Software Releases Eclipse Plug-In at JavaOne
Skyway Software announced a strategic partnership with SpringSource. In this technology partnership,
Virtualization Conference Keynote Webcast Live on SYS-CON.TV
Brian Stevens, the Chief Technology Officer and Vice President of Engineering of Red Hat, delivered
Red Hat Named "Platinum Sponsor" of Virtualization Conference & Expo
Red Hat is a trusted open source provider. Red Hat offers enterprise customers a long-term plan fo
Momentum for Instantiations Products Increase as Adoption of Eclipse Grows
Instantiations announced that its customer base has grown to more than 10,000 customers. Instantiati
Migration from IBM Rational Application Developer to MyEclipse 6.5 Blue Edition
Genuitec announced the availability of the milestone release of MyEclipse 6.5 Blue Edition, a tailor
Mainsoft Announces Sharepoint Integrator for IBM Lotus Notes
Mainsoft announced the release of its SharePoint Integrator for Lotus Notes. This add-on to IBM Lotu
MyEclipse 6.5 Delivers Portlets, Spring and JSF Upgrades and JAX-WS Web Services
Genuitec announced the availability of the initial milestone release of MyEclipse Enterprise Workben
AccuRev Makes Available Initial Release of Its Maven-SCM Plug-in for m2Eclipse
AccuRev announced the release of its process-centric software configuration management (SCM) plug-in
Ubuntu Here We Come! - Java Finally To Become 100% Open Source
With only two weeks to go now before JavaOne, its annual Javaganza for developers, Sun has revealed
Engelbart's Usability Dilemma: Efficiency vs Ease-of-Use
The mouse was the original idea of Doug Engelbart who was the head of the Augmentation Research Cent
VoiceObjects Desktop for Eclipse
VoiceObjects announced the availability of its VoiceObjects Desktop for Eclipse and VoiceObjects Dev
Curl Joins Eclipse Foundation and Announces Eclipse Strategy
Curl announced it has joined the Eclipse Foundation, a not-for-profit, member-supported corporation
CodeGear Announces New Release of JBuilder 2008
CodeGear announced the availability of JBuilder 2008, its latest version of the IDE for the Java pla
Web 2.0 Is Fundamentally About Empowering People
'Unlocking content to be remixed into new business value' is the driver of Web 2.0 in the enterprise
Why Do 'Cool Kids' Choose Ruby or PHP to Build Websites Instead of Java?
Here is a question that I have been pondering on and off for quite a while: Why do 'cool kids' choos
VLX Developer V2.0 Offers Support for Deploying VLX Realtime Virtualization
VrtualLogix announced the availability of VLX Developer v2.0, offering enhanced support for deployin
AMD Unveils Open Source Eclipse Plug-In
AMD announced a new plug-in that provides the Eclipse community with increased performance managemen
ADS BY GOOGLE