Giáo trình hướng dẫn phân tích mảng một chiều bằng cách sử dụng danh sách các giá trị bên trong dấu ngoặc p10
lượt xem 3
download
Thuộc tính trả về một ICollection chứa những khóa trong hashtable. Thuộc tính trả về một ICollection chứa những giá trị trong hashtable. Thêm một thành phần mới với khóa và giá trị xác định. Xóa tất cả đối tượng trong hashtable. Chỉ mục cho hastable Tạo ra một bản sao Xác định xem một thành phần có trong hashtable. Xác định xem hashtable có chứa một khóa xác định Sao chép những thành phần của hashtable đến mảng một chiều đã tồn tại Trả về một enumerator cho hashtable....
Bình luận(0) Đăng nhập để gửi bình luận!
Nội dung Text: Giáo trình hướng dẫn phân tích mảng một chiều bằng cách sử dụng danh sách các giá trị bên trong dấu ngoặc p10
- Ngôn Ngữ Lập Trình C# . Thuộc tính trả về một ICollection chứa những khóa Keys trong hashtable. Thuộc tính trả về một ICollection chứa những giá Values trị trong hashtable. Thêm một thành phần mới với khóa và giá trị xác Add() định. Xóa tất cả đối tượng trong hashtable. Clear() Chỉ mục cho hastable Item() Tạo ra một bản sao Clone() Xác định xem một thành phần có trong hashtable. Contains() Xác định xem hashtable có chứa một khóa xác ContainsKey() định Sao chép những thành phần của hashtable đến CopyTo() mảng một chiều đã tồn tại Trả về một enumerator cho hashtable. GetEnumerator() Thực thi ISerializable và trả về dữ liệu cần thiết để GetObjectData() lưu trữ. Thực thi ISerializable và phát sinh sự kiện OnDeserialization deserialization khi hoàn thành. Xóa một thành phần với khóa xác định. Remove() Bảng 9.6: Phương thức và thuộc tính của lớp Hashtable. Trong một Hashtable, mỗi giá trị được lưu trữ trong một vùng. Mỗi vùng được đánh số tương tự như là từng offset trong mảng. Do khóa có thể không phải là số nguyên, nên phải chuyển các khóa thành các khóa số để ánh xạ đến vùng giá trị được đánh số. Mỗi khóa phải cung cấp phương thức GetHashCode() để nhận giá trị mã hóa thành số của nó. Chúng ta nhớ rằng mọi thứ trong C# đều được dẫn xuất từ lớp object. Lớp object cung cấp một phương thức ảo là GetHashCode(), cho phép các lớp dẫn xuất tự do kế thừa hay viết lại. Việc thực thi thông thường của phương thức GetHashCode() đối với chuỗi thì đơn giản bằng cách cộng các giá trị Unicode của từng ký tự lại rồi sau đó sử dụng toán tử chia lấy dư để nhận lại một giá trị từ 0 đến số vùng được phân của hashtable. Ta không cần phải viết lại phương thức này với kiểu chuỗi. Khi chúng ta thêm giá trị vào Hashtable thì Hashtable sẽ gọi phương thức GetHashCode() cho mỗi giá trị mà chúng ta cung cấp. Phương thức này trả về một số nguyên, xác định vùng mà giá trị được lưu trữ trong hashtable.Dĩ nhiên là có thể nhiều giá trị nhận chung một khóa tức là cùng một vùng trong hashtable, điều này gọi là sự xung đột. Có một vài cách để giải quyết sự xung đột này. Trong đó cách chung nhất và được hỗ trợ bởi CLR là cho mỗi vùng duy trì một danh sách có thứ tự các giá trị. Khi chúng ta truy cập một giá trị trong hashtable, chúng ta cung cấp một khóa. Một lần nữa Hashtable gọi phương thức GetHashCode() trên 268 . Mảng, Chỉ Mục, và Tập Hợp
- . Ngôn Ngữ Lập Trình C# khóa và sử dụng giá trị trả về để tìm vùng tương ứng. Nếu chỉ có một giá trị thì nó sẽ trả về, nếu có nhiều hơn hai giá trị thì việc tìm kiếm nhị phân sẽ được thực hiện trên những nội dung của vùng đó. Bởi vì có một vài giá trị nên việc tìm kiếm này thực hiện thông thường là rất nhanh. Khóa trong Hashtable có thể là kiểu dữ liệu nguyên thủy hay là các thể hiện của các kiểu dữ liệu do người dùng định nghĩa (các lớp cho người lập trình tạo ra). Những đối tượng được sử dụng làm khóa trong hashtable phải thực thi GetHashCode() và Equals(). Trong hầu hết trường hợp, chúng ta có thể sử dụng kế thừa từ Object. Giao diện IDictionary là một từ điển ví nó thực thi giao diện IDictionary. IDictionary cung cấp một thuộc Hashtable tính public là Item. Thuộc tính Item truy cập một giá trị thông qua một khóa xác định. Trong ngôn ngữ C# thuộc tính Item được khai báo như sau: object this[object key] { get; set;} Thuộc tính Item được thực thi trong ngôn ngữ C# với toán tử chỉ mục ([]). Do vậy chúng ta có thể truy cập những item trong bất cứ đối tượng từ điển bằng cú pháp giống như truy cập mảng. Ví dụ 9.17 minh họa việc thêm một item vào trong bảng Hashtable và sau đó truy cập lại chúng thông qua thuộc tính Item. Ví dụ 9.17: thuộc tính Item tương như như toán tử offset. ----------------------------------------------------------------------------- namespace Programming_CSharp { using System; using System.Collections; public class Tester { static void Main() { // tạo và khởi tạo hashtable Hashtable hashTable = new Hashtable(); hashTable.Add(“00440123”,”Ngoc Thao”); hashTable.Add(“00123001”,”My Tien”); hashTable.Add(“00330124”,”Thanh Tung”); // truy cập qua thuộc tính Item Console.WriteLine(“myHashtable[\“00440123\”]: {0}”, hashTable[“00440123”]); 269 . Mảng, Chỉ Mục, và Tập Hợp
- . Ngôn Ngữ Lập Trình C# } } } ----------------------------------------------------------------------------- Kết quả: hashTable[“00440123”]: Ngoc Thao ----------------------------------------------------------------------------- Ví dụ 9.17 bắt đầu bằng việc tạo một bảng Hashtable mới, sử dụng các giá trị mặc định của dung lượng, phương thức tạo mã băm và phương tức so sánh. Tiếp sau là việc thêm 3 bộ giá trị vào theo thứ tự khóa/giá trị. Sau khi các item đã được thêm vào chúng ta có thể lấy giá trị thông qua khóa với cách thức dùng toán tử offset. Tập khóa và tập giá trị Các kiểu từ cung cấp thêm hai thuộc tính là thuộc tính Keys, và thuộc tính Values. Trong đó Keys truy cập đối tượng ICollection với tất cả những khóa trong Hashtable, và Values truy cập đối tượng ICollection với tất cả giá trị. Ví dụ 9.18 minh họa như sau. Ví dụ 9.18 Tập khóa và tập giá trị. ----------------------------------------------------------------------------- namespace Progrmming_CSharp { using System; using System.Collections; public class Tester { static void Main() { // tạo và khởi tạo hashtable Hashtable hashTable = new Hashtable(); hashTable.Add(“00440123”,”Ngoc Thao”); hashTable.Add(“00123001”,”My Tien”); hashTable.Add(“00330124”,”Thanh Tung”); // nhận tập khóa ICollection keys = hashTable.Keys; // nhập tập giá trị ICollection values = hashTable.Values; // xuất tập khóa foreach( string s in keys) { 270 . Mảng, Chỉ Mục, và Tập Hợp
- . Ngôn Ngữ Lập Trình C# Console.WriteLine(“{0}”, s); } // xuất tập giá trị foreach( string s in values) { Console.WriteLine(“{0}”, s); } } } } ----------------------------------------------------------------------------- Kết quả: 00123001 00440123 00330124 My Tien Ngoc Thao Thanh Tung ----------------------------------------------------------------------------- Mặc dù thứ tự của keys không được đảm bảo theo thứ tự nhưng chúng đảm bảo rằng cùng với thứ tự đưa ra của giá trị. Như chúng ta thấy trên khóa 00123001 tương ứng với My Tien,... Giao diện IDictionaryEnumerator Những đối tượng IDictionary cũng hỗ trợ vòng lặp foreach bằng việc thực thi phương thức GetEnumerator(), phương thức này trả về một IDictionaryEnumerator. IDictionaryEnumerator được sử dụng để liệt kê bất cứ đối tượng IDictionary nào. Nó cung cấp thuộc tính để truy cập cả khóa và giá trị cho mỗi thành phần trong từ điển. Ta có ví dụ 9.19 minh họa như sau: Ví dụ 9.16: sử dụng giao diện IDictionaryEnumerator. ----------------------------------------------------------------------------- namespace Progrmming_CSharp { using System; using System.Collections; public class Tester { static void Main() { 271 . Mảng, Chỉ Mục, và Tập Hợp
- . Ngôn Ngữ Lập Trình C# // tạo và khởi tạo hashtable Hashtable hashTable = new Hashtable(); hashTable.Add(“00440123”,”Ngoc Thao”); hashTable.Add(“00123001”,”My Tien”); hashTable.Add(“00330124”,”Thanh Tung”); Console.WriteLine(“hashTable”); Console.WriteLine(“Count: {0}”,hashTable.Count); Console.WriteLine(“Keys and Values:”); Print( hashTable ); } public static void Print(Hashtable table) { IDictionaryEnumerator enumerator = table.GetEnumerator(); while ( enumerator.MoveNext() ) { Console.WriteLine(“\t{0}:\t{1}”, enumerator.Key, enumerator.Value); } Console.WriteLine(); } } } ----------------------------------------------------------------------------- Kết quả: hashTableg Count: 3 Keys and Values: 00123001: My Tien 00440123: Ngoc Thao 00330124: Thanh Tung ----------------------------------------------------------------------------- Câu hỏi và trả lời Câu hỏi 1: Điều phân biệt giữa mảng và các thành phần bên trong một mảng? Trả lời 1: Mảng là kiểu dữ liệu tham chiếu, còn các thành phần bên trong mảng được cấp phát dựa theo kiểu dữ liệu của chúng. Do vậy một mảng của kiểu dữ liệu tham chiếu sẽ không chứa giá trị gì cả mà chỉ tham chiếu đến những thành phần được tạo ra trên heap. Câu hỏi 2: Một lớp có bộ chỉ mục khác một mảng như thế nào? 272 . Mảng, Chỉ Mục, và Tập Hợp
CÓ THỂ BẠN MUỐN DOWNLOAD
-
Giáo trình hướng dẫn phân tích các bước để tạo một select query với thiết lập các thuộc tính total và crosstab p1
5 p | 167 | 17
-
Giáo trình hướng dẫn phân tích lãi suất và giá trị của tiền tệ theo thời gian tích lũy p3
5 p | 105 | 10
-
Giáo trình hướng dẫn phân tích lãi suất và giá trị của tiền tệ theo thời gian tích lũy p9
5 p | 99 | 8
-
Giáo trình hướng dẫn phân tích cấu tạo mô hình quản lý mạng phân phối xử lý dữ liệu p6
11 p | 84 | 8
-
Giáo trình hướng dẫn phân tích cấu tạo mô hình quản lý mạng phân phối xử lý dữ liệu p4
11 p | 94 | 6
-
Giáo trình hướng dẫn phân tích ứng dụng phương thức gán đối tượng cho một giao diện đối lập trừu tượng p8
5 p | 87 | 5
-
Giáo trình hướng dẫn phân tích cấu tạo mô hình quản lý mạng phân phối xử lý dữ liệu p7
11 p | 77 | 4
-
Giáo trình hướng dẫn phân tích cấu tạo mô hình quản lý mạng phân phối xử lý dữ liệu p3
11 p | 81 | 4
-
Giáo trình hướng dẫn phân tích cấu tạo mô hình quản lý mạng phân phối xử lý dữ liệu p2
11 p | 88 | 4
-
Giáo trình hướng dẫn phân tích cấu tạo mô hình quản lý mạng phân phối xử lý dữ liệu p1
11 p | 91 | 4
-
Giáo trình hướng dẫn phân tích khả năng chống phân mảnh dung lượng ổ cứng bằng Clean system p3
5 p | 86 | 3
-
Giáo trình hướng dẫn phân tích cấu tạo mô hình quản lý mạng phân phối xử lý dữ liệu p10
11 p | 71 | 3
-
Giáo trình hướng dẫn phân tích cấu tạo mô hình quản lý mạng phân phối xử lý dữ liệu p9
11 p | 63 | 3
-
Giáo trình hướng dẫn phân tích cấu tạo mô hình quản lý mạng phân phối xử lý dữ liệu p8
11 p | 75 | 3
-
Giáo trình hướng dẫn phân tích khả năng chống phân mảnh dung lượng ổ cứng bằng Clean system p1
5 p | 75 | 2
-
Giáo trình hướng dẫn phân tích khả năng chống phân mảnh dung lượng ổ cứng bằng Clean system p2
5 p | 67 | 2
-
Giáo trình hướng dẫn phân tích khả năng chống phân mảnh dung lượng ổ cứng bằng Clean system p5
5 p | 64 | 2
-
Giáo trình hướng dẫn phân tích khả năng chống phân mảnh dung lượng ổ cứng bằng Clean system p6
5 p | 90 | 2
Chịu trách nhiệm nội dung:
Nguyễn Công Hà - Giám đốc Công ty TNHH TÀI LIỆU TRỰC TUYẾN VI NA
LIÊN HỆ
Địa chỉ: P402, 54A Nơ Trang Long, Phường 14, Q.Bình Thạnh, TP.HCM
Hotline: 093 303 0098
Email: support@tailieu.vn