My .NET Olai

Console.WriteLine("My experiences surrounding the .NET world in which I've been living since my graduation");


Just Another .NET Blog

MerryMan

Wednesday, July 28, 2004

Why not read a book for your collegues!

I have now originally copied an idea from Rick. The idea is on how to make myself read a book. Rick started by writing out snippets (in his own words) from a book he was reading. Not just writing it for himself, he was sending them as mails to the collegues.

It so happened that for sometime such mails stopped which prompted me to mail him to ask about the proceedings. He said he shall continue doing it. Which makes him read the book.

I have also started to do something like that now. I am reading the “Essential .NET - The CLR” by Don Box. And not just that. In our internal forum, a new forum has been dedicated to this purpose. (email becomes cumbersome due to maintainance problems).

Advantages:

  • I get to read the book as collegues expect something every day.
  • I also get to summarize what I have read (best method to retain knowledge is to share it).
  • Collegues also get to read the book at a glance.

got to code now.....

Saturday, July 17, 2004

A different advantage of multi-language support in .NET

Today, I had to create the skeleton VS.NET solution along with the different .NET projects that would go into the solution for a new project at my workplace.

The reason I chose today as the day for this is that I could see someone starting to go ahead with the project development like some student hacking his way around. I have lost the patience to even look at such kind of coding. Worst is the case when there are files named “WebForm1.aspx” and “WebApplication1.sln”. If not today then never it will be. If substantial amount of coding goes into the project then the natural tendency to resist change occurs and the result is spaghetti code. ( ”Denial is the most predictable of all human responses” - from Matrix - http://www.neoandtrinity.net/)

In my previous ASP.NET web application project, majority of the time was spent on setting up the environment and learning new stuff.( VSS to CVS transition, 3-Tier Architecture, User Interface Process, Authoring Web Pages, Web Menu, User Controls, Authentication & Authorization, Coding Guidelines, Javascript and Asp.Net co-existence, DataGrids, Session Expiration, Understanding Struts to understand MVC, Deployment etc...). In fact, every damn thing was new. Not much time was devoted on implementing most of the suggestions in “Real-world tips for Real-world web application” web-cast by Paul D. Sheriff, President, PDSA Inc. Almost all the tips are right on target and gives the viewer enormous confidence and courage to immediatly try including them in their current project. And quite a few of the tips were incorporated. I was scared to experiment more due to the UIP application block being used (which in itself is mind-bogling stuff).

This project will not use the UIPAB and hence the decision to start with business logic coding only when all the real-world tips are included. At this precise moment, I've included 6 of 10 tips in this project (The coding for which started about 9 hours back). A more elaborate webcast on N-Tier programming (”Designing LOB applications using Asp.NET”) was refered and hence a different project folder structure has been adopted.
  • N-Tier programming (done)
  • Application Settings (done)
  • User Interface
  • Base Page Class (done)
  • Track Users (next in the task queue)
  • Exception Management (done)
  • Session Variable Usage (done)
  • Manage Unhandled Exceptions (done)
  • Security (doing...)
  • Performance

Now, let me come to the relation of this post with that of its subject. The code sample provided and refered by Paul D. Sheriff was written using VB.NET and the project I am developing is using C#. So, most of the time I had to replicate the code in C# for which I had to understand VB.NET code also. This process of looking at a code written in another .NET language and writting the same functionality in another .NET language is very fascinating. Some of the syntax I used to take for granted were made to understand.


Now, one might argue that this can be done with other languages also. Advantage in this case is that both VB.NET and C# uses the underlying FCL and thus makes it very easy to do the conversion and hence the learning. Imaging doing the same from Java to C# (I guess this might also be easy owing to the fact that many OSS existing in Java are now being written in C#).
I've now decided that to understand any code, best method is to re-write the code using some other language. I think VB.NET developers will get a better grip on Object-Oriented languages by using this technique.


Also, for the first time I have thought about the number of lines of coding that has gone in today. Stumbled upon the “devMetrics” tool for C# code analysis and reporting. Unfortunately, It is not enabling the Analyze... option from the VS.NET 2003 IDE. But, I could generate the report using the Command Line facility and found that the amout of code written today by me is approx. 250 lines.


Ok... Time to take a nap and go home in the morning....

Saturday, July 10, 2004

Training the non-techies on .NET!

“How to train the non-techies on .NET?“

“What should you start with and where to stop?”

These were just a couple of challenges I had to face this week at the training program organized at my workplace for the freshmen who joined our team a couple of weeks back.

The challenge becomes more interesting when the group consists of few computer science graduates and few non-computer science graduates.

There needs to be a balance in the amount of information departed. More technical terms, and the ideas will bounce off the non-techie group. Using more general terms to explain any stuff becomes more trivial for techies.

We'll the agenda was to instill the basics of .NET and a proper foundation so that the later sessions (C#, ASP.NET, ADO.NET) have no difficulty.

Keeping that in mind, I decided to use the same presentation I had used at the
CorporateConnexion @ Christ College. On review, found that it was loaded with technical stuff and may bounce off even the techie freshmen.

So, that presentation now had to be trimmed.

First, I decided to instill the idea that:

.NET was not any single software
.NET has been mainly been developed to create Enterprise Applications

To get this idea instilled, used an anology of a House Construction and Enterprise Application Construction.

This made it possible to understand “Where exactly .NET fits into the Software Industry?”

The second half was to just clear the jargons surrounding .NET

Just displayed the various components of .NET that will be used to create an enterprise application.

The various types of applications that can be created (Web Application, Desktop Application)

The various role played by Asp.NET, Ado.NET, Web Forms, WinForms

The presentation can be found here