C # Coding Standards for.net By Lance Hunt. Document Version 1.15 March Copyright Lance Hunt 2007 All Rights Reserved
|
|
|
- Charla Hart
- 10 years ago
- Views:
Transcription
1 C # Coding Standards for.net By Lance Hunt Document Version 1.15 March 2007 Copyright Lance Hunt 2007 All Rights Reserved Published by Lance Hunt Please submit comments, questions, and feedback to
2 License Usage & Distribution This document is FREE for commercial, personal, academic, and non-commercial use in its original unmodified form. Publication of the work or derivation of the work in any form is prohibited unless a valid license is obtained from the copyright holder. Commercial redistribution of the work or derivative of the work in any form is prohibited unless a valid license is obtained from the copyright holder. Non-commercial redistribution of the work is permitted in its original unmodified form so long as all license and all copyright notices are retained and respected. Trademarks All uses of terms that are known trademarks or service marks have been appropriately capitalized. The Publisher cannot attest to the accuracy of this information. Use of terms within this work should not be regarded as affecting the validity of any trademark or service mark. All Trademarks are the property of their respective owners. Disclaimer The information provided is on an As-Is basis. Use at your own risk. The Author and Publisher shall have neither liability nor responsibility to any person or entity with respect to the loss or damages arising from the information contained in this work. This work may include inaccuracies or typographical errors and solely represent the opinions of the Author. Changes are periodically made to this document without notice. Any action related to this work will be governed by Texas state law and controlling U.S. federal law. No choice of law rules of any jurisdiction will apply. The Author reserves the right to revise these terms or terminate the above license at any time without notice. i
3 Table of Contents Table of Contents 1. Introduction Scope Document Conventions Terminology & Definitions Flags Naming Conventions Coding Style Language Usage Naming Conventions General Guidelines Name Usage & Syntax Coding Style Formatting Code Commenting Language Usage General Variables & Types Flow Control Exceptions Events, Delegates, & Threading Object Composition Object Model & API Design References ii
4 1. Introduction This document describes rules and recommendations for developing applications and class libraries using the C# Language. The goal is to define guidelines to enforce consistent style and formatting and help developers avoid common pitfalls and mistakes. Specifically, this document covers Naming Conventions, Coding Style, Language Usage, and Object Model Design. 1.1 Scope This document only applies to the C# Language and the.net Framework Common Type System(CTS) it implements. Although the C# language is implemented alongside the.net Framework, this document does not address usage of.net Framework class libraries. However, common patterns and problems related to C# s usage of the.net Framework are addressed in a limited fashion. Even though standards for curly-braces ( or ) and white space(tabs vs. spaces) are always controversial, these topics are addressed here to ensure greater consistency and maintainability of source code. 1.2 Document Conventions Much like the ensuing coding standards, this document requires standards in order to ensure clarity when stating the rules and guidelines. Certain conventions are used throughout this document to add emphasis. Below are some of the common conventions used throughout this document. Coloring & Emphasis: Blue Bold Text colored blue indicates a C# keyword or.net type. Text with additional emphasis to make it stand-out. Keywords: Always Never Do Not Avoid Try Example Reason Emphasizes this rule must be enforced. Emphasizes this action must not happen. Emphasizes this action must not happen. Emphasizes that the action should be prevented, but some exceptions may exist. Emphasizes that the rule should be attempted whenever possible and appropriate. Precedes text used to illustrate a rule or recommendation. Explains the thoughts and purpose behind a rule or recommendation. 1
5 1.3 Terminology & Definitions The following terminology is referenced throughout this document: Access Modifier C# keywords public, protected, internal, and private declare the allowed code-accessibility of types and their members. Although default access modifiers vary, classes and most other members use the default of private. Notable exceptions are interfaces and enums which both default to public. Camel Case A word with the first letter lowercase, and the first letter of each subsequent word-part capitalized. customername Common Type System The.NET Framework common type system (CTS) defines how types are declared, used, and managed. All native C# types are based upon the CTS to ensure support for cross-language integration. Identifier A developer defined token used to uniquely name a declared object or object instance. public class MyClassName NameIdentifier Magic Number Any numeric literal used within an expression (or to initialize a variable) that does not have an obvious or wellknown meaning. This usually excludes the integers 0 or 1 and any other numeric equivalent precision that evaluates as zero. Pascal Case A word with the first letter capitalized, and the first letter of each subsequent word-part capitalized. CustomerName Premature Generalization As it applies to object model design; this is the act of creating abstractions within an object model not based upon concrete requirements or a known future need for the abstraction. In simplest terms: Abstraction for the sake of Abstraction. 1.4 Flags The following flags are used to help clarify or categorize certain statements: [C#v2+] A flag to identify rules and statements that apply only to C# Language Specification v2.0 or greater. 2
6 Quick Summary This section contains tables describing a high-level summary of the major standards covered in this document. These tables are not comprehensive, but give a quick glance at commonly referenced elements Naming Conventions c = camelcase P = PascalCase _ = Prefix with _Underscore x = Not Applicable. Identifier Public Protected Internal Private Notes Project File P x x x Match Assembly & Namespace. Source File P x x x Match contained class. Other Files P x x x Apply where possible. Namespace P x x x Partial Project/Assembly match. Class or Struct P P P P Add suffix of subclass. Interface P P P P Prefix with a capital I. Generic Class P P P P Use T or K as Type identifier. [C#v2+] Method P P P P Use a Verb or Verb-Object pair. Property P P P P Do not prefix with Get or Set. Field P P P _c Only use Private fields. No Hungarian Notation! Constant P P P _c Static Field P P P _c Only use Private fields. Enum P P P P Options are also PascalCase. Delegate P P P P Event P P P P Inline Variable x x x c Avoid single-character and enumerated names. Parameter x x x c Coding Style Code Style Source Files One Namespace per file and one class per file. Curly Braces On new line. Always use braces when optional. Indention Use tabs with size of 4. Comments Use // or /// but not /* */ and do not flowerbox. Variables One variable per declaration. 3
7 1.4.3 Language Usage Code Native Data Types Enums Generics [C#v2+] Properties Methods base and this Ternary conditions foreach statements Conditionals Exceptions Events Locking Dispose() & Close() Finalizers AssemblyVersion ComVisibleAttribute Style Use built-in C# native data types vs.net CTS types. (Use int NOT Int32) Avoid changing default type. Prefer Generic Types over standard or strong-typed classes. Never prefix with Get or Set. Use a maximum of 7 parameters. Use only in constructors or within an override. Avoid complex conditions. Do not modify enumerated items within a foreach statement. Avoid evaluating Boolean conditions against true or false. No embedded assignment. Avoid embedded method invocation. Do not use exceptions for flow control. Use throw; not throw e; when re-throwing. Only catch what you can handle. Use validation to avoid exceptions. Derive from Execption not ApplicationException. Always check for null before invoking. Use lock() not Monitor.Enter(). Do not lock on an object type or this. Do lock on private objects. Always invoke them if offered, declare where needed. Avoid. Use the C# Destructors. Do not create Finalize() method. Increment manually. Set to false for all assemblies. 4
8 2. Naming Conventions Consistency is the key to maintainable code. This statement is most true for naming your projects, source files, and identifiers including Fields, Variables, Properties, Methods, Parameters, Classes, Interfaces, and Namespaces. 2.1 General Guidelines 1. Always use Camel Case or Pascal Case names. 2. Avoid ALL CAPS and all lowercase names. Single lowercase words or letters are acceptable. 3. Do not create declarations of the same type (namespace, class, method, property, field, or parameter) and access modifier (protected, public, private, internal) that vary only by capitalization. 4. Do not use names that begin with a numeric character. 5. Do add numeric suffixes to identifier names. 6. Always choose meaningful and specific names. 7. Always err on the side of verbosity not terseness. 8. Variables and Properties should describe an entity not the type or size. 9. Do not use Hungarian Notation! strname or icount 10. Avoid using abbreviations unless the full name is excessive. 11. Avoid abbreviations longer than 5 characters. 12. Any Abbreviations must be widely known and accepted. 13. Use uppercase for two-letter abbreviations, and Pascal Case for longer abbreviations. 14. Do not use C# reserved words as names. 15. Avoid naming conflicts with existing.net Framework namespaces, or types. 16. Avoid adding redundant or meaningless prefixes and suffixes to identifiers // Bad! public enum ColorsEnum public class CVehicle public struct RectangleStruct 17. Do not include the parent class name within a property name. Customer.Name NOT Customer.CustomerName 18. Try to prefix Boolean variables and properties with Can, Is or Has. 19. Append computational qualifiers to variable names like Average, Count, Sum, Min, and Max where appropriate. 20. When defining a root namespace, use a Product, Company, or Developer Name as the root. LanceHunt.StringUtilities 5
9 2.2 Name Usage & Syntax Identifier Project File Naming Convention Pascal Case. Always match Assembly Name & Root Namespace. LanceHunt.Web.csproj -> LanceHunt.Web.dll -> namespace LanceHunt.Web Source File Pascal Case. Always match Class name and file name. Avoid including more than one Class, Enum (global), or Delegate (global) per file. Use a descriptive file name when containing multiple Class, Enum, or Delegates. MyClass.cs => public class MyClass Resource or Embedded File Namespace Try to use Pascal Case. Use a name describing the file contents. Pascal Case. Try to partially match Project/Assembly Name. namespace LanceHunt.Web Class or Struct Pascal Case. Use a noun or noun phrase for class name. Add an appropriate class-suffix when sub-classing another type when possible. Examples: private class MyClass internal class SpecializedAttribute : Attribute public class CustomerCollection : CollectionBase public class CustomEventArgs : EventArgs private struct ApplicationSettings Interface Pascal Case. Always prefix interface name with capital I. interface ICustomer 6
10 Generic Class & Generic Parameter Type [C#v2+] Method Always use a single capital letter, such as T or K. public class FifoStack<T> public void Push(<T> obj) public <T> Pop() Pascal Case. Try to use a Verb or Verb-Object pair. public void Execute() private string GetAssemblyVersion(Assembly target) Property Pascal Case. Property name should represent the entity it returns. Never prefix property names with Get or Set. public string Name get set Field (Public, Protected, or Internal) Pascal Case. Avoid using non-private Fields! Use Properties instead. public string Name; protected IList InnerList; Field (Private) Camel Case and prefix with a single underscore (_) character. private string _name; Constant or Static Field Enum Treat like a Field. Choose appropriate Field access-modifier above. Pascal Case (both the Type and the Options). Add the FlagsAttribute to bit-mask multiple options. public enum CustomerTypes Consumer, Commercial 7
11 Delegate or Event Treat as a Field. Choose appropriate Field access-modifier above. public event EventHandler LoadPlugin; Variable (inline) Parameter Camel Case. Avoid using single characters like x or y except in FOR loops. Avoid enumerating variable names like text1, text2, text3 etc. Camel Case. public void Execute(string commandtext, int iterations) 8
12 3. Coding Style Coding style causes the most inconsistency and controversy between developers. Each developer has a preference, and rarely are two the same. However, consistent layout, format, and organization are key to creating maintainable code. The following sections describe the preferred way to implement C# source code in order to create readable, clear, and consistent code that is easy to understand and maintain. 3.1 Formatting 1. Never declare more than 1 namespace per file. 2. Avoid putting multiple classes in a single file. 3. Always place curly braces ( and ) on a new line. 4. Always use curly braces ( and ) in conditional statements. 5. Always use a Tab & Indention size of Declare each variable independently not in the same statement. 7. Place namespace using statements together at the top of file. Group.NET namespaces above custom namespaces. 8. Group internal class implementation by type in the following order: a. Member variables. b. Constructors & Finalizers. c. Nested Enums, Structs, and Classes. d. Properties e. Methods 9. Sequence declarations within type groups based upon access modifier and visibility: a. Public b. Protected c. Internal d. Private 10. Segregate interface Implementation by using #region statements. 11. Append folder-name to namespace for source files within sub-folders. 12. Recursively indent all code blocks contained within braces. 13. Use white space (CR/LF, Tabs, etc) liberally to separate and organize code. 14. Only declare related attribute declarations on a single line, otherwise stack each attribute as a separate declaration. // Bad! [Attrbute1, Attrbute2, Attrbute3] public class MyClass // Good! [Attrbute1, RelatedAttribute2] [Attrbute3] [Attrbute4] public class MyClass 15. Place Assembly scope attribute declarations on a separate line. 16. Place Type scope attribute declarations on a separate line. 17. Place Method scope attribute declarations on a separate line. 18. Place Member scope attribute declarations on a separate line. 19. Place Parameter attribute declarations inline with the parameter. 20. If in doubt, always err on the side of clarity and consistency. 9
13 3.2 Code Commenting 21. All comments should be written in the same language, be grammatically correct, and contain appropriate punctuation. 22. Use // or /// but never /* */ 23. Do not flowerbox comment blocks. // *************************************** // Comment block // *************************************** 24. Use inline-comments to explain assumptions, known issues, and algorithm insights. 25. Do not use inline-comments to explain obvious code. Well written code is self documenting. 26. Only use comments for bad code to say fix this code otherwise remove, or rewrite the code! 27. Include comments using Task-List keyword flags to allow comment-filtering. // TODO: Place Database Code Here // UNDONE: Removed P\Invoke Call due to errors // HACK: Temporary fix until able to refactor 28. Always apply C# comment-blocks (///) to public, protected, and internal declarations. 29. Only use C# comment-blocks for documenting the API. 30. Always include <summary> comments. Include <param>, <return>, and <exception> comment sections where applicable. 31. Include <see cref= /> and <seealso cref= /> where possible. 32. Always add CDATA tags to comments containing code and other embedded markup in order to avoid encoding issues. /// <example> /// Add the following key to the appsettings section of your config: /// <code><![cdata[ <![CDATA[ /// <configuration> /// <appsettings> /// <add key= mysetting value= myvalue /> /// </appsettings> /// </configuration> /// ]]></code> /// </example> 10
14 4. Language Usage 4.1 General 1. Do not omit access modifiers. Explicitly declare all identifiers with the appropriate access modifier instead of allowing the default. // Bad! Void WriteEvent(string message) // Good! private Void WriteEvent(string message) 2. Do not use the default ( 1.0.* ) versioning scheme. Increment the AssemblyVersionAttribute value manually. 3. Set the ComVisibleAttribute to false for all assemblies. 4. Only selectively enable the ComVisibleAttribute for individual classes when needed. [assembly: ComVisible(false)] [ComVisible(true)] public MyClass 5. Consider factoring classes containing unsafe code blocks into a separate assembly. 6. Avoid mutual references between assemblies. 4.2 Variables & Types 7. Try to initialize variables where you declare them. 8. Always choose the simplest data type, list, or object required. 9. Always use the built-in C# data type aliases, not the.net common type system (CTS). short NOT System.Int16 int NOT System.Int32 long NOT System.Int64 string NOT System.String 10. Only declare member variables as private. Use properties to provide access to them with public, protected, or internal access modifiers. 11. Try to use int for any non-fractional numeric values that will fit the int datatype - even variables for nonnegative numbers. 12. Only use long for variables potentially containing values too large for an int. 13. Try to use double for fractional numbers to ensure decimal precision in calculations. 14. Only use float for fractional numbers that will not fit double or decimal. 15. Avoid using float unless you fully understand the implications upon any calculations. 16. Try to use decimal when fractional numbers must be rounded to a fixed precision for calculations. Typically this will involve money. 17. Avoid using sbyte, short, uint, and ulong unless it is for interop (P/Invoke) with native libraries. 11
15 18. Avoid specifying the type for an enum - use the default of int unless you have an explicit need for long (very uncommon). 19. Avoid using inline numeric literals (magic numbers). Instead, use a Constant or Enum. 20. Avoid declaring string literals inline. Instead use Resources, Constants, Configuration Files, Registry or other data sources. 21. Declare readonly or static readonly variables instead of constants for complex types. 22. Only declare constants for simple types. 23. Avoid direct casts. Instead, use the as operator and check for null. object dataobject = LoadData(); DataSet ds = dataobject as DataSet; if(ds!= null) 24. Always prefer C# Generic collection types over standard or strong-typed collections. [C#v2+] 25. Always explicitly initialize arrays of reference types using a for loop. 26. Avoid boxing and unboxing value types. int count = 1; object refcount = count; // Implicitly boxed. int newcount = (int)refcount; // Explicitly unboxed. 27. Floating point values should include at least one digit before the decimal place and one after. totalpercent = 0.05; 28. Try to use prefix for string literals instead of escaped strings. 29. Prefer String.Format() or StringBuilder over string concatenation. 30. Never concatenate strings inside a loop. 31. Do not compare strings to String.Empty or to check for empty strings. Instead, compare by using String.Length == Avoid hidden string allocations within a loop. Use String.Compare() for case-sensitive (ToLower() creates a temp string) 12
16 // Bad! int id = -1; string name = lance hunt ; for(int i=0; i < customerlist.count; i++) if(customerlist[i].name.tolower() == name) id = customerlist[i].id; // Good! int id = -1; string name = lance hunt ; for(int i=0; i < customerlist.count; i++) // The ignorecase = true argument performs a // case-insensitive compare without new allocation. if(string.compare String.Compare(customerList[i].Name, name, true)== 0) id = customerlist[i].id; 4.3 Flow Control 33. Avoid invoking methods within a conditional expression. 34. Avoid creating recursive methods. Use loops or nested loops instead. 35. Avoid using foreach to iterate over immutable value-type collections. E.g. String arrays. 36. Do not modify enumerated items within a foreach statement. 37. Use the ternary conditional operator only for trivial conditions. Avoid complex or compound ternary operations. int result = isvalid? 9 : 4; 38. Avoid evaluating Boolean conditions against true or false. // Bad! if (isvalid == true) // Good! if (isvalid) 39. Avoid assignment within conditional statements. if((i=2 i=2)==2) 13
17 40. Avoid compound conditional expressions use Boolean variables to split parts into multiple manageable expressions. // Bad! if (((value > _highscore) && (value!= _highscore)) && (value < _maxscore)) // Good! ishighscore = (value >= _highscore); istiedhigh = (value == _highscore); isvalid = (value < _maxvalue); if ((ishighscore &&! istiedhigh) && isvalid) 41. Avoid explicit Boolean tests in conditionals. // Bad! if(isvalid == true) ; // Good! if(isvalid) 42. Only use switch/case statements for simple operations with parallel conditional logic. 43. Prefer nested if/else over switch/case for short conditional sequences and complex conditions. 44. Prefer polymorphism over switch/case to encapsulate and delegate complex operations. 4.4 Exceptions 45. Do not use try/catch blocks for flow-control. 46. Only catch exceptions that you can handle. 47. Never declare an empty catch block. 48. Avoid nesting a try/catch within a catch block. 49. Always catch the most derived exception via exception filters. 50. Order exception filters from most to least derived exception type. 51. Avoid re-throwing an exception. Allow it to bubble-up instead. 52. If re-throwing an exception, preserve the original call stack by omitting the exception argument from the throw statement. // Bad! catch(exception ex) Log(ex); throw ex; // Good! catch(exception) Log(ex); throw; 53. Only use the finally block to release resources from a try statement. 14
18 54. Always use validation to avoid exceptions. // Bad! try conn.close(); Catch(Exception ex) // handle exception if already closed! // Good! if(conn.state!= ConnectionState.Closed) conn.close(); 55. Always set the innerexception property on thrown exceptions so the exception chain & call stack are maintained. 56. Avoid defining custom exception classes. Use existing exception classes instead. 57. When a custom exception is required; a. Always derive from Exception not ApplicationException. b. Always suffix exception class names with the word Exception. c. Always add the SerializableAttribute to exception classes. d. Always implement the standard Exception Constructor Pattern : public MyCustomException (); public MyCustomException (string message); public MyCustomException (string message, Exception innerexception); e. Always implement the deserialization constructor: protected MyCustomException(SerializationInfo info, StreamingContext contxt); 58. Always set the appropriate HResult value on custom exception classes. (Note: the ApplicationException HResult = ) 59. When defining custom exception classes that contain additional properties: a. Always override the Message property, ToString() method and the implicit operator string to include custom property values. b. Always modify the deserialization constructor to retrieve custom property values. c. Always override the GetObjectData( ) method to add custom properties to the serialization collection. public override void GetObjectData(SerializationInfo info, StreamingContext context) base.getobjectdata (info, context); info.addvalue("myvalue", _myvalue); 4.5 Events, Delegates, & Threading 60. Always check Event & Delegate instances for null before invoking. 61. Use the default EventHandler and EventArgs for most simple events. 62. Always derive a custom EventArgs class to provide additional data. 63. Use the existing CancelEventArgs class to allow the event subscriber to control events. 64. Always use the lock keyword instead of the Monitor type. 65. Only lock on a private or private static object. lock(myvariable); 15
19 66. Avoid locking on a Type. lock(typeof(myclass)); 67. Avoid locking on the current object instance. lock(this); 4.6 Object Composition 68. Always declare types explicitly within a namespace. Do not use the default global namespace. 69. Avoid overuse of the public access modifier. Typically fewer than 10% of your types and members will be part of a public API, unless you are writing a class library. 70. Consider using internal or private access modifiers for types and members unless you intend to support them as part of a public API. 71. Never use the protected access modifier within sealed classes unless overriding a protected member of an inherited type. 72. Avoid declaring methods with more than 5 parameters. Consider refactoring this code. 73. Try to replace large parameter-sets (> than 5 parameters) with one or more class or struct parameters especially when used in multiple method signatures. 74. Do not use the new keyword on method and property declarations to hide members of a derived type. 75. Only use the base keyword when invoking a base class constructor or base implementation within an override. 76. Consider using method overloading instead of the params attribute (but be careful not to break CLS Compliance of your API s). 77. Always validate an enumeration variable or parameter value before consuming it. They may contain any value that the underlying Enum type (default int) supports. public void Test(BookCategory cat) if (Enum.IsDefined(typeof(BookCategory), cat)) 78. Consider overriding Equals() on a struct. 79. Always override the Equality Operator (==) when overriding the Equals() method. 80. Always override the String Implicit Operator when overriding the ToString() method. 81. Always call Close() or Dispose() on classes that offer it. 82. Wrap instantiation of IDisposable objects with a using statement to ensure that Dispose() is automatically called. using(sqlconnection cn = new SqlConnection(_connectionString)) 16
20 83. Always implement the IDisposable interface & pattern on classes referencing external resources. (shown with optional Finalizer) public void Dispose() Dispose(true); GC.SuppressFinalize(this); protected virtual void Dispose(bool disposing) if (disposing) // Free other state (managed objects). // Free your own state (unmanaged objects). // Set large fields to null. // C# finalizer. (optional) ~Base() // Simply call Dispose(false). Dispose (false); 84. Avoid implementing a Finalizer. Never define a Finalize() method as a finalizer. Instead use the C# destructor syntax. Example // Good ~MyClass // Bad void Finalize() 17
21 5. Object Model & API Design 1. Always prefer aggregation over inheritance. 2. Avoid Premature Generalization. Create abstractions only when the intent is understood. 3. Do the simplest thing that works, then refactor when necessary. 4. Always make object-behavior transparent to API consumers. 5. Avoid unexpected side-affects when properties, methods, and constructors are invoked. 6. Always separate presentation layer from business logic. 7. Always prefer interfaces over abstract classes. 8. Try to include the design-pattern names such as Bridge, Adapter, or Factory as a suffix to class names where appropriate. 9. Only make members virtual if they are designed and tested for extensibility. 10. Refactor often! 18
22 6. References MSDN:.NET Framework Developer s Guide: Common Type System, Microsoft Corporation, 2004, MSDN: C# Language Specification v1.5, Scott Wiltamuth & Anders Hejlsberg, Microsoft Corporation, 2003, MSDN: Design Guidelines for Class Library Developers, Microsoft Corporation, 2004, MSDN: The Well Tempered Exception, Eric Gunnerson, Microsoft Corporation, Applied Microsoft.NET Framework Programming, Jeffrey Richter, January 23, 2002, 1st ed., Microsoft Press, ISBN: Which type should I use in C# to represent numbers?, locabol, February 27, 2007, Luca Bolognese s Weblog
Coding Standards for C#
DotNetDaily.net Coding Standards for C# This document was downloaded from http://www.dotnetdaily.net/ You are permitted to use and distribute this document for any noncommercial purpose as long as you
C Coding Style Guide. Technotes, HowTo Series. 1 About the C# Coding Style Guide. 2 File Organization. Version 0.3. Contents
Technotes, HowTo Series C Coding Style Guide Version 0.3 by Mike Krüger, [email protected] Contents 1 About the C# Coding Style Guide. 1 2 File Organization 1 3 Indentation 2 4 Comments. 3 5 Declarations.
PROBLEM SOLVING SEVENTH EDITION WALTER SAVITCH UNIVERSITY OF CALIFORNIA, SAN DIEGO CONTRIBUTOR KENRICK MOCK UNIVERSITY OF ALASKA, ANCHORAGE PEARSON
PROBLEM SOLVING WITH SEVENTH EDITION WALTER SAVITCH UNIVERSITY OF CALIFORNIA, SAN DIEGO CONTRIBUTOR KENRICK MOCK UNIVERSITY OF ALASKA, ANCHORAGE PEARSON Addison Wesley Boston San Francisco New York London
Objectif. Participant. Prérequis. Remarque. Programme. C# 3.0 Programming in the.net Framework. 1. Introduction to the.
Objectif This six-day instructor-led course provides students with the knowledge and skills to develop applications in the.net 3.5 using the C# 3.0 programming language. C# is one of the most popular programming
09336863931 : provid.ir
provid.ir 09336863931 : NET Architecture Core CSharp o Variable o Variable Scope o Type Inference o Namespaces o Preprocessor Directives Statements and Flow of Execution o If Statement o Switch Statement
Fundamentals of Java Programming
Fundamentals of Java Programming This document is exclusive property of Cisco Systems, Inc. Permission is granted to print and copy this document for non-commercial distribution and exclusive use by instructors
AP Computer Science Java Subset
APPENDIX A AP Computer Science Java Subset The AP Java subset is intended to outline the features of Java that may appear on the AP Computer Science A Exam. The AP Java subset is NOT intended as an overall
Philips Healthcare - C# Coding Standard
Philips Healthcare - C# Coding Standard Version 2.0 (c) 2009, Philips Healthcare issued by the CCB Coding Standards Philips Healthcare External Use of this Document The C# coding standard as defined by
Java Interview Questions and Answers
1. What is the most important feature of Java? Java is a platform independent language. 2. What do you mean by platform independence? Platform independence means that we can write and compile the java
Java Application Developer Certificate Program Competencies
Java Application Developer Certificate Program Competencies After completing the following units, you will be able to: Basic Programming Logic Explain the steps involved in the program development cycle
CSE 308. Coding Conventions. Reference
CSE 308 Coding Conventions Reference Java Coding Conventions googlestyleguide.googlecode.com/svn/trunk/javaguide.html Java Naming Conventions www.ibm.com/developerworks/library/ws-tipnamingconv.html 2
Moving from CS 61A Scheme to CS 61B Java
Moving from CS 61A Scheme to CS 61B Java Introduction Java is an object-oriented language. This document describes some of the differences between object-oriented programming in Scheme (which we hope you
Object Oriented Software Design II
Object Oriented Software Design II Introduction to C++ Giuseppe Lipari http://retis.sssup.it/~lipari Scuola Superiore Sant Anna Pisa February 20, 2012 G. Lipari (Scuola Superiore Sant Anna) C++ Intro February
Glossary of Object Oriented Terms
Appendix E Glossary of Object Oriented Terms abstract class: A class primarily intended to define an instance, but can not be instantiated without additional methods. abstract data type: An abstraction
Course Name: ADVANCE COURSE IN SOFTWARE DEVELOPMENT (Specialization:.Net Technologies)
Course Name: ADVANCE COURSE IN SOFTWARE DEVELOPMENT (Specialization:.Net Technologies) Duration of Course: 6 Months Fees: Rs. 25,000/- (including Service Tax) Eligibility: B.E./B.Tech., M.Sc.(IT/ computer
Object-Oriented Programming in C# (VS 2010)
Object-Oriented Programming in C# (VS 2010) Description: This thorough and comprehensive five-day course is a practical introduction to programming in C#, utilizing the services provided by.net. This course
Programming with the Microsoft.NET Framework Using Microsoft Visual Studio 2005 (VB)
Programming with the Microsoft.NET Framework Using Microsoft Visual Studio 2005 (VB) Course Number: 4995 Length: 5 Day(s) Certification Exam There are no exams associated with this course. Course Overview
Changes to credit card processing in Microsoft Dynamics AX 2012 R2
Microsoft Dynamics AX Changes to credit card processing in Microsoft Dynamics AX 2012 R2 Implementation Note This document explains what has changed in the implementation of credit card processing in Accounts
Getting Started with the Internet Communications Engine
Getting Started with the Internet Communications Engine David Vriezen April 7, 2014 Contents 1 Introduction 2 2 About Ice 2 2.1 Proxies................................. 2 3 Setting Up ICE 2 4 Slices 2
C#5.0 IN A NUTSHELL. Joseph O'REILLY. Albahari and Ben Albahari. Fifth Edition. Tokyo. Sebastopol. Beijing. Cambridge. Koln.
Koln C#5.0 IN A NUTSHELL Fifth Edition Joseph Albahari and Ben Albahari O'REILLY Beijing Cambridge Farnham Sebastopol Tokyo Table of Contents Preface xi 1. Introducing C# and the.net Framework 1 Object
Java (12 Weeks) Introduction to Java Programming Language
Java (12 Weeks) Topic Lecture No. Introduction to Java Programming Language 1 An Introduction to Java o Java as a Programming Platform, The Java "White Paper" Buzzwords, Java and the Internet, A Short
CS 111 Classes I 1. Software Organization View to this point:
CS 111 Classes I 1 Software Organization View to this point: Data Objects and primitive types Primitive types operators (+, /,,*, %). int, float, double, char, boolean Memory location holds the data Objects
EMC Documentum Application Connectors Software Development Kit
EMC Documentum Application Connectors Software Development Kit Version 6.8 Development Guide EMC Corporation Corporate Headquarters: Hopkinton, MA 01748-9103 1-508-435-1000 www.emc.com Legal Notice Copyright
C++ INTERVIEW QUESTIONS
C++ INTERVIEW QUESTIONS http://www.tutorialspoint.com/cplusplus/cpp_interview_questions.htm Copyright tutorialspoint.com Dear readers, these C++ Interview Questions have been designed specially to get
JavaScript: Control Statements I
1 7 JavaScript: Control Statements I 7.1 Introduction 2 The techniques you will learn here are applicable to most high-level languages, including JavaScript 1 7.2 Algorithms 3 Any computable problem can
Storage Classes CS 110B - Rule Storage Classes Page 18-1 \handouts\storclas
CS 110B - Rule Storage Classes Page 18-1 Attributes are distinctive features of a variable. Data type, int or double for example, is an attribute. Storage class is another attribute. There are four storage
Object Oriented Software Design
Object Oriented Software Design Introduction to Java - II Giuseppe Lipari http://retis.sssup.it/~lipari Scuola Superiore Sant Anna Pisa October 28, 2010 G. Lipari (Scuola Superiore Sant Anna) Introduction
AppendixA1A1. Java Language Coding Guidelines. A1.1 Introduction
AppendixA1A1 Java Language Coding Guidelines A1.1 Introduction This coding style guide is a simplified version of one that has been used with good success both in industrial practice and for college courses.
El Dorado Union High School District Educational Services
El Dorado Union High School District Course of Study Information Page Course Title: ACE Computer Programming II (#495) Rationale: A continuum of courses, including advanced classes in technology is needed.
Dinopolis Java Coding Convention
Dinopolis Java Coding Convention Revision : 1.1 January 11, 2001 Abstract Please note that this version of the Coding convention is very much based on IICM s internal Dino coding convention that was used
DIPLOMADO DE JAVA - OCA
DIPLOMADO DE JAVA - OCA TABLA DE CONTENIDO INTRODUCCION... 3 ESTRUCTURA DEL DIPLOMADO... 4 Nivel I:... 4 Fundamentals of the Java Programming Language Java SE 7... 4 Introducing the Java Technology...
Object Oriented Software Design
Object Oriented Software Design Introduction to Java - II Giuseppe Lipari http://retis.sssup.it/~lipari Scuola Superiore Sant Anna Pisa September 14, 2011 G. Lipari (Scuola Superiore Sant Anna) Introduction
Computer Programming I
Computer Programming I COP 2210 Syllabus Spring Semester 2012 Instructor: Greg Shaw Office: ECS 313 (Engineering and Computer Science Bldg) Office Hours: Tuesday: 2:50 4:50, 7:45 8:30 Thursday: 2:50 4:50,
Name: Class: Date: 9. The compiler ignores all comments they are there strictly for the convenience of anyone reading the program.
Name: Class: Date: Exam #1 - Prep True/False Indicate whether the statement is true or false. 1. Programming is the process of writing a computer program in a language that the computer can respond to
Applied Informatics C++ Coding Style Guide
C++ Coding Style Guide Rules and Recommendations Version 1.4 Purpose of This Document This document describes the C++ coding style employed by Applied Informatics. The document is targeted at developers
PL / SQL Basics. Chapter 3
PL / SQL Basics Chapter 3 PL / SQL Basics PL / SQL block Lexical units Variable declarations PL / SQL types Expressions and operators PL / SQL control structures PL / SQL style guide 2 PL / SQL Block Basic
History OOP languages Year Language 1967 Simula-67 1983 Smalltalk
History OOP languages Intro 1 Year Language reported dates vary for some languages... design Vs delievered 1957 Fortran High level programming language 1958 Lisp 1959 Cobol 1960 Algol Structured Programming
The Sun Certified Associate for the Java Platform, Standard Edition, Exam Version 1.0
The following applies to all exams: Once exam vouchers are purchased you have up to one year from the date of purchase to use it. Each voucher is valid for one exam and may only be used at an Authorized
JetBrains ReSharper 2.0 Overview Introduction ReSharper is undoubtedly the most intelligent add-in to Visual Studio.NET 2003 and 2005. It greatly increases the productivity of C# and ASP.NET developers,
Facebook Twitter YouTube Google Plus Website Email
PHP MySQL COURSE WITH OOP COURSE COVERS: PHP MySQL OBJECT ORIENTED PROGRAMMING WITH PHP SYLLABUS PHP 1. Writing PHP scripts- Writing PHP scripts, learn about PHP code structure, how to write and execute
Android Application Development Course Program
Android Application Development Course Program Part I Introduction to Programming 1. Introduction to programming. Compilers, interpreters, virtual machines. Primitive data types, variables, basic operators,
Oracle Database: SQL and PL/SQL Fundamentals
Oracle University Contact Us: 1.800.529.0165 Oracle Database: SQL and PL/SQL Fundamentals Duration: 5 Days What you will learn This course is designed to deliver the fundamentals of SQL and PL/SQL along
Java SE 7 Programming
Java SE 7 Programming The second of two courses that cover the Java Standard Edition 7 (Java SE 7) Platform, this course covers the core Application Programming Interfaces (API) you will use to design
AP Computer Science A - Syllabus Overview of AP Computer Science A Computer Facilities
AP Computer Science A - Syllabus Overview of AP Computer Science A Computer Facilities The classroom is set up like a traditional classroom on the left side of the room. This is where I will conduct my
ECE 341 Coding Standard
Page1 ECE 341 Coding Standard Professor Richard Wall University of Idaho Moscow, ID 83843-1023 [email protected] August 27, 2013 1. Motivation for Coding Standards The purpose of implementing a coding standard
This tutorial has been prepared for the beginners to help them understand basics of c# Programming.
1 About the Tutorial C# is a simple, modern, general-purpose, object-oriented programming language developed by Microsoft within its.net initiative led by Anders Hejlsberg. This tutorial covers basic C#
ARIZONA CTE CAREER PREPARATION STANDARDS & MEASUREMENT CRITERIA SOFTWARE DEVELOPMENT, 15.1200.40
SOFTWARE DEVELOPMENT, 15.1200.40 1.0 APPLY PROBLEM-SOLVING AND CRITICAL THINKING SKILLS TO INFORMATION TECHNOLOGY 1.1 Describe methods and considerations for prioritizing and scheduling software development
Item 7: Prefer Immutable Atomic Value Types
Item 7: Prefer Immutable Atomic Value Types 1 Item 7: Prefer Immutable Atomic Value Types Immutable types are simple: After they are created, they are constant. If you validate the parameters used to construct
Programming and Software Development (PSD)
Programming and Software Development (PSD) Course Descriptions Fundamentals of Information Systems Technology This course is a survey of computer technologies. This course may include computer history,
Free Java textbook available online. Introduction to the Java programming language. Compilation. A simple java program
Free Java textbook available online "Thinking in Java" by Bruce Eckel, 4th edition, 2006, ISBN 0131872486, Pearson Education Introduction to the Java programming language CS 4354 Summer II 2015 The third
Official Android Coding Style Conventions
2012 Marty Hall Official Android Coding Style Conventions Originals of Slides and Source Code for Examples: http://www.coreservlets.com/android-tutorial/ Customized Java EE Training: http://courses.coreservlets.com/
Install Java Development Kit (JDK) 1.8 http://www.oracle.com/technetwork/java/javase/downloads/index.html
CS 259: Data Structures with Java Hello World with the IntelliJ IDE Instructor: Joel Castellanos e-mail: joel.unm.edu Web: http://cs.unm.edu/~joel/ Office: Farris Engineering Center 319 8/19/2015 Install
Basic Programming and PC Skills: Basic Programming and PC Skills:
Texas University Interscholastic League Contest Event: Computer Science The contest challenges high school students to gain an understanding of the significance of computation as well as the details of
Domains and Competencies
Domains and Competencies DOMAIN I TECHNOLOGY APPLICATIONS CORE Standards Assessed: Computer Science 8 12 I VII Competency 001: The computer science teacher knows technology terminology and concepts; the
Introduction to Visual Studio and C#
Telemark University College Department of Electrical Engineering, Information Technology and Cybernetics Introduction to Visual Studio and C# HANS- PETTER HALVORSEN, 2014.03.12 Faculty of Technology, Postboks
Java SE 8 Programming
Oracle University Contact Us: 1.800.529.0165 Java SE 8 Programming Duration: 5 Days What you will learn This Java SE 8 Programming training covers the core language features and Application Programming
Course Title: Software Development
Course Title: Software Development Unit: Customer Service Content Standard(s) and Depth of 1. Analyze customer software needs and system requirements to design an information technology-based project plan.
JavaScript. JavaScript: fundamentals, concepts, object model. Document Object Model. The Web Page. The window object (1/2) The document object
JavaScript: fundamentals, concepts, object model Prof. Ing. Andrea Omicini II Facoltà di Ingegneria, Cesena Alma Mater Studiorum, Università di Bologna [email protected] JavaScript A scripting language:
WebSphere Business Monitor
WebSphere Business Monitor Monitor models 2010 IBM Corporation This presentation should provide an overview of monitor models in WebSphere Business Monitor. WBPM_Monitor_MonitorModels.ppt Page 1 of 25
The C Programming Language course syllabus associate level
TECHNOLOGIES The C Programming Language course syllabus associate level Course description The course fully covers the basics of programming in the C programming language and demonstrates fundamental programming
Developer Updates for. Microsoft Dynamics NAV
Microsoft Dynamics NAV Developer Updates for Microsoft Dynamics NAV 2009 R2 User's Guide December 2010 Contents Developer Updates for Microsoft Dynamics NAV 2009 R2... 1 Viewing the Definition of a Function
Visual Basic. murach's TRAINING & REFERENCE
TRAINING & REFERENCE murach's Visual Basic 2008 Anne Boehm lbm Mike Murach & Associates, Inc. H 1-800-221-5528 (559) 440-9071 Fax: (559) 440-0963 [email protected] www.murach.com Contents Introduction
Volume I, Section 4 Table of Contents
Volume I, Section 4 Table of Contents 4 Software Standards...4-1 4.1 Scope...4-1 4.1.1 Software Sources...4-2 4.1.2 Location and Control of Software and Hardware on Which it Operates...4-2 4.1.3 Exclusions...4-3
Software Development (CS2500)
(CS2500) Lecture 15: JavaDoc and November 6, 2009 Outline Today we study: The documentation mechanism. Some important Java coding conventions. From now on you should use and make your code comply to the
This module explains fundamental aspects of Microsoft Dynamics NAV Development Environment.
MICROSOFT DYNAMICS NAV COURSE OUTLINE 1) MICROSOFT DYNAMICS NAV Module 1: Microsoft Dynamics NAV Development Environment This module explains fundamental aspects of Microsoft Dynamics NAV Development Environment.
Computer Programming I & II*
Computer Programming I & II* Career Cluster Information Technology Course Code 10152 Prerequisite(s) Computer Applications, Introduction to Information Technology Careers (recommended), Computer Hardware
Free Java textbook available online. Introduction to the Java programming language. Compilation. A simple java program
Free Java textbook available online "Thinking in Java" by Bruce Eckel, 4th edition, 2006, ISBN 0131872486, Pearson Education Introduction to the Java programming language CS 4354 Summer II 2014 Jill Seaman
Web Development in Java
Web Development in Java Detailed Course Brochure @All Rights Reserved. Techcanvass, 265, Powai Plaza, Hiranandani Garden, Powai, Mumbai www.techcanvass.com Tel: +91 22 40155175 Mob: 773 877 3108 P a g
JavaScript: Introduction to Scripting. 2008 Pearson Education, Inc. All rights reserved.
1 6 JavaScript: Introduction to Scripting 2 Comment is free, but facts are sacred. C. P. Scott The creditor hath a better memory than the debtor. James Howell When faced with a decision, I always ask,
Computer Programming I
Computer Programming I Levels: 10-12 Units of Credit: 1.0 CIP Code: 11.0201 Core Code: 35-02-00-00-030 Prerequisites: Secondary Math I, Keyboarding Proficiency, Computer Literacy requirement (e.g. Exploring
Oracle Database: SQL and PL/SQL Fundamentals NEW
Oracle University Contact Us: + 38516306373 Oracle Database: SQL and PL/SQL Fundamentals NEW Duration: 5 Days What you will learn This Oracle Database: SQL and PL/SQL Fundamentals training delivers the
Specialized Programme on Web Application Development using Open Source Tools
Specialized Programme on Web Application Development using Open Source Tools A. NAME OF INSTITUTE Centre For Development of Advanced Computing B. NAME/TITLE OF THE COURSE C. COURSE DATES WITH DURATION
Programming Languages CIS 443
Course Objectives Programming Languages CIS 443 0.1 Lexical analysis Syntax Semantics Functional programming Variable lifetime and scoping Parameter passing Object-oriented programming Continuations Exception
Topics. Parts of a Java Program. Topics (2) CS 146. Introduction To Computers And Java Chapter Objectives To understand:
Introduction to Programming and Algorithms Module 2 CS 146 Sam Houston State University Dr. Tim McGuire Introduction To Computers And Java Chapter Objectives To understand: the meaning and placement of
Summit Public Schools Summit, New Jersey Grade Level / Content Area: Mathematics Length of Course: 1 Academic Year Curriculum: AP Computer Science A
Summit Public Schools Summit, New Jersey Grade Level / Content Area: Mathematics Length of Course: 1 Academic Year Curriculum: AP Computer Science A Developed By Brian Weinfeld Course Description: AP Computer
DTD Tutorial. About the tutorial. Tutorial
About the tutorial Tutorial Simply Easy Learning 2 About the tutorial DTD Tutorial XML Document Type Declaration commonly known as DTD is a way to describe precisely the XML language. DTDs check the validity
C# Cookbook. Stephen Teilhet andjay Hilyard. O'REILLY 8 Beijing Cambridge Farnham Köln Paris Sebastopol Taipei Tokyo '"J""'
C# Cookbook '"J""' Stephen Teilhet andjay Hilyard O'REILLY 8 Beijing Cambridge Farnham Köln Paris Sebastopol Taipei Tokyo Tableof Contents Preface xv 1. Numbers 1 1.1 Determining Approximate Equality Between
Java 7 Recipes. Freddy Guime. vk» (,\['«** g!p#« Carl Dea. Josh Juneau. John O'Conner
1 vk» Java 7 Recipes (,\['«** - < g!p#«josh Juneau Carl Dea Freddy Guime John O'Conner Contents J Contents at a Glance About the Authors About the Technical Reviewers Acknowledgments Introduction iv xvi
Introduction This document s purpose is to define Microsoft SQL server database design standards.
Introduction This document s purpose is to define Microsoft SQL server database design standards. The database being developed or changed should be depicted in an ERD (Entity Relationship Diagram). The
TYLER JUNIOR COLLEGE School of Continuing Studies 1530 SSW Loop 323 Tyler, TX 75701 1.800.298.5226 www.tjc.edu/continuingstudies/mycaa
TYLER JUNIOR COLLEGE School of Continuing Studies 1530 SSW Loop 323 Tyler, TX 75701 1.800.298.5226 www.tjc.edu/continuingstudies/mycaa Education & Training Plan Java Programming Specialist Program Student
Bachelors of Computer Application Programming Principle & Algorithm (BCA-S102T)
Unit- I Introduction to c Language: C is a general-purpose computer programming language developed between 1969 and 1973 by Dennis Ritchie at the Bell Telephone Laboratories for use with the Unix operating
.NET and J2EE Intro to Software Engineering
.NET and J2EE Intro to Software Engineering David Talby This Lecture.NET Platform The Framework CLR and C# J2EE Platform And Web Services Introduction to Software Engineering The Software Crisis Methodologies
Java SE 7 Programming
Oracle University Contact Us: 1.800.529.0165 Java SE 7 Programming Duration: 5 Days What you will learn This Java SE 7 Programming training explores the core Application Programming Interfaces (API) you'll
Java SE 7 Programming
Oracle University Contact Us: Local: 1800 103 4775 Intl: +91 80 4108 4709 Java SE 7 Programming Duration: 5 Days What you will learn This Java Programming training covers the core Application Programming
To Java SE 8, and Beyond (Plan B)
11-12-13 To Java SE 8, and Beyond (Plan B) Francisco Morero Peyrona EMEA Java Community Leader 8 9...2012 2020? Priorities for the Java Platforms Grow Developer Base Grow Adoption
Developer Guide. Christian W. Günther [email protected]. Library version: 1.0 RC7 Revision: 7
Developer Guide Christian W. Günther [email protected] Library version: 1.0 RC7 Revision: 7 November 14, 2009 The XES Meta-model Introduction Event logs, as they occur in practice and research, can
Handout 1. Introduction to Java programming language. Java primitive types and operations. Reading keyboard Input using class Scanner.
Handout 1 CS603 Object-Oriented Programming Fall 15 Page 1 of 11 Handout 1 Introduction to Java programming language. Java primitive types and operations. Reading keyboard Input using class Scanner. Java
Importing Lease Data into Forms Online
Blue Moon Software presents May 2012 Importing Lease Data into Forms Online A Developer's Guide Edited by Michael Phillipson wwwbluemooncom Table of Contents XML and the Blue Moon DTD 1 Login Data1 Login
C++ Language Tutorial
cplusplus.com C++ Language Tutorial Written by: Juan Soulié Last revision: June, 2007 Available online at: http://www.cplusplus.com/doc/tutorial/ The online version is constantly revised and may contain
Taxi Service Coding Policy. Version 1.2
Taxi Service Coding Policy Version 1.2 Revision History Date Version Description Author 2012-10-31 1.0 Initial version Karlo Zanki 2012-11-18 1.1 Added a section relative to Java/Android Fabio Kruger 2013-01-02
Code convention document Argus-viewer
Code convention document Projectnaam: Auteur(s): Reviewer(s): Software Process case voor master-studie Software Engineering 2007/2008. Robert Baarda (Q&A) Studentnr.: 5821258 Martijn van Beest (Q&A) Ka-Sing
Charles Dierbach. Wiley
Charles Dierbach Wiley Contents Preface Acknowledgments About the Author XXI xxv xxvii Introduction 1 MOTIVATION 2 FUNDAMENTALS 2 1.1 What Is Computer Science? 2 1.1.1 The Essence of Computational Problem
Web Development Naming Conventions
Web Development Naming Conventions Author: Erik Giberti Date: September 28, 2006 Revision: Draft 1.0 Summary: A document covering topics regarding variable, filename, database and directory naming and
An Incomplete C++ Primer. University of Wyoming MA 5310
An Incomplete C++ Primer University of Wyoming MA 5310 Professor Craig C. Douglas http://www.mgnet.org/~douglas/classes/na-sc/notes/c++primer.pdf C++ is a legacy programming language, as is other languages
Advanced Web Development SCOPE OF WEB DEVELOPMENT INDUSTRY
Advanced Web Development Duration: 6 Months SCOPE OF WEB DEVELOPMENT INDUSTRY Web development jobs have taken thе hot seat when it comes to career opportunities and positions as a Web developer, as every
2 Collections Framework Overview
2 Collections Framework Overview Chapter 2 Contax T Sidewalk Collections Framework Overview Learning Objectives List the four namespaces that constitute the.net collections framework Understand the organization
Java 6 'th. Concepts INTERNATIONAL STUDENT VERSION. edition
Java 6 'th edition Concepts INTERNATIONAL STUDENT VERSION CONTENTS PREFACE vii SPECIAL FEATURES xxviii chapter i INTRODUCTION 1 1.1 What Is Programming? 2 J.2 The Anatomy of a Computer 3 1.3 Translating
core. Volume I - Fundamentals Seventh Edition Sun Microsystems Press A Prentice Hall Title ULB Darmstadt
core. 2008 AGI-Information Management Consultants May be used for personal purporses only or by libraries associated to dandelon.com network. Volume I - Fundamentals Seventh Edition CAY S. HORSTMANN GARY
