


C# basic knowledge compilation: basic knowledge (15) ICollection, iteration and generics
1. ICollection interface
Array is the most basic collection type defined by .net framework. In addition to arrays, .net framework also defines many collection types. Open msdn and you can see that all collections are under the System.Collections namespace:
Collection class:
ArrayList: Implement the IList interface using an array whose size can be dynamically increased on demand.
BitArray: A compressed array that manages the value. The value is expressed as a Boolean value. true indicates that the bit is on (1), and false indicates that the bit is off (0).
CaseInsensitiveComparer: Compares two objects for equality, ignoring the case of strings when comparing.
CollectionBase: Provides an abstract base class for strongly typed collections.
Comparer: Compares two objects for equality, where string comparison is case-sensitive.
DictionaryBase: Provides an abstract base class for strongly typed collections of key/value pairs
Hashtable: Represents a collection of key/value pairs organized according to the hash code of the key.
Queue: Represents a first-in-first-out collection of objects
ReadOnlyCollectionBase: Provides an abstract base class for strongly typed non-generic read-only collections.
SortedList: Represents a collection of key/value pairs that are sorted by key and accessible by key and index.
Stack: Represents a simple last-in-first-out non-generic collection of objects.
Interface:
ICollection: Defines the size, enumeration and synchronization methods of all non-generic collections.
IComparer: Exposes a method for comparing two objects.
IDictionary: Represents a non-universal collection of key/value pairs.
IDictionaryEnumerator: Enumerate the elements of a non-generic dictionary.
IEnumerable: Public enumerator that supports simple iteration over non-generic collections.
IEnumerator: Supports simple iteration of non-generic collections.
IEqualityComparer: Defines methods to support equality comparison of objects.
IList: Represents a non-generic collection of objects that can be accessed individually by index.
Mainly look at the ICollection interface and IEnumerable interface.
ICollection:
This interface defines two main specifications for its implementation class:
(1) The number of collection elements, that is, the Count attribute;
(2) Iteration (GetEnumerator method).
The GetEnumertor method is inherited from ICollection's parent interface IEumerable. The ICollection interface defines a collection that stores and obtains references to object type objects, so that references to various reference type objects or value type objects can be stored and obtained.
IEnumerable interface:
This interface is the parent interface of ICollection. This interface provides iterable capabilities for the classes it implements. The IEumerable interface has only one GetEnumerator method, which returns an enumerator that iterates through the collection
2. Iteration
Iteration, also called iterator, is the iteration mode in the design pattern. The meaning is: providing a method for sequential access. Aggregates the elements in an object without exposing the object's internal representation. Because the storage methods of collections are different, List is continuous storage, and linked list uses reference storage between objects... Then it is inconvenient when you need to traverse collections, and you need a method that can traverse all different collections. This has iterators.
The iterator treats the combined class as an infinite-capacity container, and the storage rules are linear. That is, every element except the first and last one has a direct predecessor and direct successor, and the container has a flag that can point to any storage unit in the container. There are two ways: one-way iteration and two-way iteration.
(1) One-way iteration
One-way iteration refers to forward iteration only. The unit mark of the set can only move backward one by one starting from an element of the set. Therefore, iteration defines three operations:
a. Current item
b. Go to the next item and determine whether it is the end
c. Return to the initial item
(2), Bidirectional iteration mode
For bidirectional iteration mode, The unit mark of the set can move backward one by one starting from an item in the set, or it can move forward one by one starting from an item in the set. Therefore, there are four operations:
a, current item
b, forward to Next item and judge whether it is the end
c, go back to the previous item and judge whether it is the beginning of the set
d, return to the initial position
.net framework defines a one-way iteration specification using the IEumerable interface. The ICollection interface inherits the IEumerable interface. The GetEnumerator method defined by this interface can obtain an iterative object of the current collection class object, that is, an object that implements the IEumerable interface.
Any class that implements the IEnumerable interface can be iteratively traversed using a foreach loop.
The IEnumerator interface defines an iterator that can traverse object type object references, and the IEnumerable interface defines a method for obtaining such an iterator object.
3. Generic collection
ICollection
ICollection
Since the storage type has been determined, ICollection
IEnumerable
The ICollection
The above is the compilation of C# basic knowledge: Basic knowledge (15) ICollection, iteration and generics. For more related content, please pay attention to the PHP Chinese website (www.php.cn)!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



In C language, special characters are processed through escape sequences, such as: \n represents line breaks. \t means tab character. Use escape sequences or character constants to represent special characters, such as char c = '\n'. Note that the backslash needs to be escaped twice. Different platforms and compilers may have different escape sequences, please consult the documentation.

In C, the char type is used in strings: 1. Store a single character; 2. Use an array to represent a string and end with a null terminator; 3. Operate through a string operation function; 4. Read or output a string from the keyboard.

The usage methods of symbols in C language cover arithmetic, assignment, conditions, logic, bit operators, etc. Arithmetic operators are used for basic mathematical operations, assignment operators are used for assignment and addition, subtraction, multiplication and division assignment, condition operators are used for different operations according to conditions, logical operators are used for logical operations, bit operators are used for bit-level operations, and special constants are used to represent null pointers, end-of-file markers, and non-numeric values.

In C language, the main difference between char and wchar_t is character encoding: char uses ASCII or extends ASCII, wchar_t uses Unicode; char takes up 1-2 bytes, wchar_t takes up 2-4 bytes; char is suitable for English text, wchar_t is suitable for multilingual text; char is widely supported, wchar_t depends on whether the compiler and operating system support Unicode; char is limited in character range, wchar_t has a larger character range, and special functions are used for arithmetic operations.

The difference between multithreading and asynchronous is that multithreading executes multiple threads at the same time, while asynchronously performs operations without blocking the current thread. Multithreading is used for compute-intensive tasks, while asynchronously is used for user interaction. The advantage of multi-threading is to improve computing performance, while the advantage of asynchronous is to not block UI threads. Choosing multithreading or asynchronous depends on the nature of the task: Computation-intensive tasks use multithreading, tasks that interact with external resources and need to keep UI responsiveness use asynchronous.

In C language, char type conversion can be directly converted to another type by: casting: using casting characters. Automatic type conversion: When one type of data can accommodate another type of value, the compiler automatically converts it.

The char array stores character sequences in C language and is declared as char array_name[size]. The access element is passed through the subscript operator, and the element ends with the null terminator '\0', which represents the end point of the string. The C language provides a variety of string manipulation functions, such as strlen(), strcpy(), strcat() and strcmp().

There is no built-in sum function in C language, so it needs to be written by yourself. Sum can be achieved by traversing the array and accumulating elements: Loop version: Sum is calculated using for loop and array length. Pointer version: Use pointers to point to array elements, and efficient summing is achieved through self-increment pointers. Dynamically allocate array version: Dynamically allocate arrays and manage memory yourself, ensuring that allocated memory is freed to prevent memory leaks.
