The mysteries of software development and networking... RSS 2.0



 Tuesday, February 21, 2006

Today I had a discussion about coding guidelines and in particular about the size of a class, the number of methods in a class and the number of lines of code per class. What is right?

Ofcourse a little search on Google revealed millions of hits. Some of the more useful ones were:

Most standards don't say much about the size of a class, the number of methods in a class and the number of lines of code per class. The few that do say something come fairly close.

Here's the sum of guidelines that I think I'll stick by:

  1. A source file should only contain one class
  2. A method should be no more than 30 lines of code, excluding blank lines and comments
  3. A source file should contain no more than 1000 lines, including blanks and comments
  4. An interface should have no more than 10 methods, excluding overloads, ie. the combination of overloads counts as one methods
  5. C# 2.0 allows partial classes:
    • a source file should only contain one partial class
    • don't split the implementation of an interface across multiple files
    • for large classes split the implementation of interfaces and implement one interface per file
      • Filename:  <classname>.<interfacename>.cs
    • if you have a class which implements one interace, but has a lot of private methods, then create a partial class with just the private methods:
      • Filename: <classname>.private.cs

Ad 2.
This is the average I found and seems to make sense, since this means that with one look at the screen your brain can absorb the whole method.

Ad 3.
I'm not convinced this is a very important rule. Having 2000 lines of code in one file or spread across two classes in two files doesn't really make that big a difference to me. See also ad 5.

Ad 4.
This is mainly because of Intellisense. Ten methods will provide optimum use of Intellisense.

Ad 5.
Partial classes are great!

Tuesday, February 21, 2006 6:15:16 AM (Eastern Standard Time, UTC-05:00)  #    Comments [2] -
C# | General
Tracked by:
"vdgop" (vdgop) [Trackback]
"6rab7" (6rab7) [Trackback]
"AIU Online" (AIU Online) [Trackback]
"redirect" (redirect) [Trackback]
"Jones International University" (Jones International University) [Trackback]
"ghbp9" (ghbp9) [Trackback]
"AIU Online" (AIU Online) [Trackback]
http://www.walshperformancegroup.com/measurement.htm [Trackback]
"Online Education Finder - Online Degrees - Online Masters Degrees ..." (... [Trackback]
http://www.walshperformancegroup.com/assessment.htm [Trackback]
"Jones International University" (Jones International University) [Trackback]
"Online Education Finder - Online Degrees - Online Masters Degrees ..." (... [Trackback]
"Keller Graduate School of Management" (Keller Graduate School of Management) [Trackback]
"obl3y" (obl3y) [Trackback]
"AIU Online" (AIU Online) [Trackback]
"bfduk" (bfduk) [Trackback]
"b4fg1" (b4fg1) [Trackback]
"Keller Graduate School of Management" (Keller Graduate School of Management) [Trackback]
http://www.walshperformancegroup.com/training.htm [Trackback]
"Jones International University" (Jones International University) [Trackback]
"Online Masters Degrees Programs - Education Online" (Online Masters Degrees Pro... [Trackback]
"Keller Graduate School of Management" (Keller Graduate School of Management) [Trackback]
"redirect" (redirect) [Trackback]
"Victorian Clothing" (Victorian Clothing) [Trackback]
"bed and breakfast maine" (bed and breakfast maine) [Trackback]
"anti deppresant Celexa" (anti deppresant Celexa) [Trackback]
"arizona child support guidelines" (arizona child support guidelines) [Trackback]
"drag boat racing pictures" (drag boat racing pictures) [Trackback]
"summit county colorado real estate" (summit county colorado real estate) [Trackback]
"hong kong restaurants" (hong kong restaurants) [Trackback]
"orange county ca real estate" (orange county ca real estate) [Trackback]
"Adderall in Mexico" (Adderall in Mexico) [Trackback]
"auto air conditioning repair" (auto air conditioning repair) [Trackback]
"Hair Color Advice" (Hair Color Advice) [Trackback]
"columbia greene community college" (columbia greene community college) [Trackback]
"asian bitches online" (asian bitches online) [Trackback]
"freshman mandated to live in dorms" (freshman mandated to live in dorms) [Trackback]
"what is human resources" (what is human resources) [Trackback]
"yamaha keyboards" (yamaha keyboards) [Trackback]
"child abuse stories" (child abuse stories) [Trackback]
"used pontoon boat trailers in wisconsin" (used pontoon boat trailers in wiscons... [Trackback]
"narrow water ireland" (narrow water ireland) [Trackback]
"advertising comps" (advertising comps) [Trackback]
"2004 suzuki marauder 1600 horsepower" (2004 suzuki marauder 1600 horsepower) [Trackback]
"doppler rentals" (doppler rentals) [Trackback]
"Suunto sm-36" (Suunto sm-36) [Trackback]
"orchid lore" (orchid lore) [Trackback]
"cum on face prague escorts" (cum on face prague escorts) [Trackback]
"license plate restoration" (license plate restoration) [Trackback]
"manatee online banking" (manatee online banking) [Trackback]
"Funny Voice Mail Greetings" (Funny Voice Mail Greetings) [Trackback]
"Maintaining a Healthy Prostate" (Maintaining a Healthy Prostate) [Trackback]
"water injection for cummins" (water injection for cummins) [Trackback]
"cialis attorney" (cialis attorney) [Trackback]
"halo figures" (halo figures) [Trackback]
"disaster relief Katrina" (disaster relief Katrina) [Trackback]
"What is Naproxen" (What is Naproxen) [Trackback]
"managed servers" (managed servers) [Trackback]
"ragazzavirtuale" (ragazzavirtuale) [Trackback]
"despacho abogados barcelona" (despacho abogados barcelona) [Trackback]
"Unlock My Mobile Phone by Remote" (Unlock My Mobile Phone by Remote) [Trackback]
"personal helicopter" (personal helicopter) [Trackback]
"History of Philippine Film" (History of Philippine Film) [Trackback]
"Adhd Adult Quiz" (Adhd Adult Quiz) [Trackback]
"tray ceiling" (tray ceiling) [Trackback]
"hong kong cookware" (hong kong cookware) [Trackback]
"asking citizenship status a crime" (asking citizenship status a crime) [Trackback]
"murad acne complex results" (murad acne complex results) [Trackback]
"the entertainer piano music" (the entertainer piano music) [Trackback]
"1998 suburban engine upgrade" (1998 suburban engine upgrade) [Trackback]
"plus size dress apparel" (plus size dress apparel) [Trackback]
"umbrella tent" (umbrella tent) [Trackback]
"Iron Maiden Art" (Iron Maiden Art) [Trackback]
"illustrated erotic stories" (illustrated erotic stories) [Trackback]
"Aurifil thread" (Aurifil thread) [Trackback]
"SUITCASE NUKES" (SUITCASE NUKES) [Trackback]
"automodellismomotorescoppio" (automodellismomotorescoppio) [Trackback]
"gxt" (gxt) [Trackback]
"tessile" (tessile) [Trackback]
"piucaldocelestecastra" (piucaldocelestecastra) [Trackback]
"bets in roulette" (bets in roulette) [Trackback]
"eroina" (eroina) [Trackback]
"Actual Roulette Wheel" (Actual Roulette Wheel) [Trackback]
"hotelchicago" (hotelchicago) [Trackback]
"will ferrell snl" (will ferrell snl) [Trackback]
"black jack pizza coupon" (black jack pizza coupon) [Trackback]
"asiatichefottiloinufficio" (asiatichefottiloinufficio) [Trackback]
"nintendo64" (nintendo64) [Trackback]
"maravenier" (maravenier) [Trackback]
"american morgage asso.little rock arkansas" (american morgage asso.little rock ... [Trackback]
"confrontotraassicurazioni" (confrontotraassicurazioni) [Trackback]
"legal betting online" (legal betting online) [Trackback]
"dogpile spyware blocker" (dogpile spyware blocker) [Trackback]
"capital property investment" (capital property investment) [Trackback]
"vacanzastudioallestero" (vacanzastudioallestero) [Trackback]
"tuttidvdedicola" (tuttidvdedicola) [Trackback]
"jacks black book" (jacks black book) [Trackback]
"search engine optimization jobs" (search engine optimization jobs) [Trackback]
"lavorospoleto" (lavorospoleto) [Trackback]
"celestialenubile" (celestialenubile) [Trackback]
"batman year one" (batman year one) [Trackback]
"batman hat" (batman hat) [Trackback]
"Opening and betting" (Opening and betting) [Trackback]
"distributorigiochi" (distributorigiochi) [Trackback]
"corporate bingo idea" (corporate bingo idea) [Trackback]
"casavacanzaaffittopuglia" (casavacanzaaffittopuglia) [Trackback]
"lavanderiaselfservice" (lavanderiaselfservice) [Trackback]
"casino hotel rio vegas" (casino hotel rio vegas) [Trackback]
"automated window blinds" (automated window blinds) [Trackback]
"dye paintball" (dye paintball) [Trackback]
"bypass oil filtration 6.0 psd" (bypass oil filtration 6.0 psd) [Trackback]
"taiho jutsu" (taiho jutsu) [Trackback]
"barberton daisies" (barberton daisies) [Trackback]
"juicy couture tea dye purse" (juicy couture tea dye purse) [Trackback]
"safia ama jan" (safia ama jan) [Trackback]
"narcisse joseph dagenais" (narcisse joseph dagenais) [Trackback]
"daido 2006 mp3" (daido 2006 mp3) [Trackback]
"chelesa dagger" (chelesa dagger) [Trackback]
"summary of the landlady by roald dahl" (summary of the landlady by roald dahl) [Trackback]
"tacoma dwi laywers" (tacoma dwi laywers) [Trackback]
"daihatsu hijet air filter" (daihatsu hijet air filter) [Trackback]
"animal dagu" (animal dagu) [Trackback]
"dainty kane show stopping" (dainty kane show stopping) [Trackback]
"manic panic hair dye" (manic panic hair dye) [Trackback]
"brush guards" (brush guards) [Trackback]
"dai enko tai ogden" (dai enko tai ogden) [Trackback]
"odools dairy goats" (odools dairy goats) [Trackback]
"multi region dvd players" (multi region dvd players) [Trackback]
"panasonic dmr-es30v dvd recorder" (panasonic dmr-es30v dvd recorder) [Trackback]
"hp psc 2510xi wireless enabled all in one with lcd" (hp psc 2510xi wireless ena... [Trackback]
"www informationcentral pseg com" (www informationcentral pseg com) [Trackback]
"sony mini dv alkman" (sony mini dv alkman) [Trackback]
"chaco zong pink daisy" (chaco zong pink daisy) [Trackback]
"dyersburg state gazette" (dyersburg state gazette) [Trackback]
"jan ingenhousz" (jan ingenhousz) [Trackback]
"lenox daffodil vase" (lenox daffodil vase) [Trackback]
"daisy dukes shorts gallery" (daisy dukes shorts gallery) [Trackback]
"cliff dwellings" (cliff dwellings) [Trackback]
"dvd to avi" (dvd to avi) [Trackback]
"guard training afghanistan security psd units iraq" (guard training afghanistan... [Trackback]
"daily devotion" (daily devotion) [Trackback]
"aiysha dahlgren" (aiysha dahlgren) [Trackback]
"sony mini dv dcr trv15e" (sony mini dv dcr trv15e) [Trackback]
"game cheats for ps2" (game cheats for ps2) [Trackback]
"gerber daisy drawing" (gerber daisy drawing) [Trackback]
"breiding dagmar or dagmar breiding" (breiding dagmar or dagmar breiding) [Trackback]
"daivd beckham" (daivd beckham) [Trackback]
Thursday, February 23, 2006 6:49:53 AM (Eastern Standard Time, UTC-05:00)
Mark, you don’t comment on most controversial:-

"Code Lines are a maximum of 80 characters long"

I seem to hate this rule :)

I also think that Length of the Class and variable names should be limited to >30 Chars, else we loose the readability

Kishor
Kishor
Thursday, February 23, 2006 9:55:13 AM (Eastern Standard Time, UTC-05:00)
I don't care for the 80 chars rule.

On a 20" monitor and 1600x1200 resolution the rule makes no sense and personally I never ever seem to print code on a printer.

A limit on class and variable names does improve readability, 30 chars seems like a sensible limit.
Mark
Comments are closed.
About
This blog is run by Mark Blomsma.
© Copyright 2008
Develop-One
Sign In
Statistics
Total Posts: 337
This Year: 81
This Month: 0
This Week: 1
Comments: 94
All Content © 2008, Develop-One
DasBlog theme 'Business' created by Christoph De Baene (delarou)