ArrayList trong C#

Khóa học lập trình C# nâng cao

5.0 (2 đánh giá)
Tạo bởi Kteam Cập nhật lần cuối 11:37 30-05-2018 25.129 lượt xem 14 bình luận
Học nhanh

Danh sách bài học

ArrayList trong C#

Dẫn nhập

Ở các bài học trước, chúng ta đã cùng nhau tìm hiểu về TỔNG QUAN COLLECTIONS TRONG C#. Hôm nay chúng ta sẽ cùng tìm hiểu về ArrayList trong C#.


Nội dung

Để đọc hiểu bài này tốt nhất các bạn nên có kiến thức cơ bản về các phần:

Trong bài học này, chúng ta sẽ cùng tìm hiểu các vấn đề:

  • ArrayList là gì?
  • Một số thuộc tính và phương thức hỗ trợ sẵn trong ArrayList.

ArrayList là gì?

ArrayList trong C#:

  • Là một Collections giúp lưu trữ và quản lý một danh sách các đối tượng theo kiểu mảng (truy cập các phần tử bên trong thông qua chỉ số index).
  • Rất giống mảng các object nhưng có thể thêm hoặc xoá các phần tử một cách linh hoạt và có thể tự điều chỉnh kích cỡ một cách tự động.

Để sử dụng các Collections trong .NET ta cần thêm thư viện System.Collections bằng câu lệnh:

using System.Collections;

Vì ArrayList là một lớp nên trước khi sử dụng ta cần khởi tạo vùng nhớ bằng toán tử new:

ArrayList MyArray = new ArrayList(); // khởi tạo 1 ArrayList rỗng

Bạn cũng có chỉ định sức chứa (Capacity) ngay lúc khởi tạo bằng cách thông qua constructor được hỗ trợ sẵn:

ArrayList MyArray2 = new ArrayList(5); // khởi tạo 1 ArrayList và chỉ định Capacity ban đầu là 5

Ngoài ra bạn cũng có thể khởi tạo 1 ArrayList chứa các phần tử được sao chép từ một Collections khác:

/*
 * Khởi tạo 1 ArrayList có kích thước bằng với MyArray2.
 * Sao chép toàn độ phần tử trong MyArray2 vào MyArray3.
 */
 ArrayList MyArray3 = new ArrayList(MyArray2);

Một số thuộc tính và phương thức hỗ trợ sẵn trong ArrayList

Một số thuộc tính thông dụng trong ArrayList:

Một số phương thức thông dụng trong ArrayList:
 
 

Những phương thức trên này cũng khá đơn giản nên mình sẽ không tập trung demo chúng mà để các bạn tự khám phá. Thay vào đó mình sẽ demo những thứ hay ho hơn.

Ở trên mình có giới thiệu phương thức Sort() sẽ thực hiện sắp xếp danh sách theo thứ tự tăng dần. Vậy nếu danh sách của mình gồm các đối tượng mà mỗi đối tượng là 1 lớp có nhiều thuộc tính thì hàm Sort này biết sắp xếp tăng dần theo thuộc tính nào?

Để trả lời câu hỏi này thì chúng ta cần biết thêm là còn 1 hàm Sort nữa được hỗ trợ sẵn trong ArrayList có cú pháp như sau:

Sort(IComparer comparer)

Công dụng:

  • Hàm này cho phép người dùng tự định nghĩa cách sắp xếp theo ý mình.
  • Tham số truyền vào là 1 lớp có kế thừa từ interface IComparer.
  • Interface IComparer chứa 1 phương thức duy nhất là:

int Comparer(object x, object y).

Phương thức này sẽ trả về 3 giá trị:

  •  Bé hơn 0 nếu x < y.
  •  Lớn hơn 0 nếu x > y.
  •  Bằng 0 nếu x = y.

Từ những quy định về inferface này ta chỉ cần khai báo 1 lớp kế thừa interface IComparer và định nghĩa nội dụng cho phương thức Comparer có giá trị trả về theo những quy định trên.


Bắt tay vào code nào:

Đầu tiên ta có 1 lớp Person đại diện cho 1 con người bao gồm 2 thông tin Name và Age.

public class Person
    {
        private string name;
        private int age;

        public string Name
        {
            get { return name; }
            set { name = value; }
        }

        public int Age
        {
            get { return age; }
            set { age = value; }
        }

        /// <summary>
        /// Tạo 1 constructor có tham số để tiện cho việc khởi tạo nhanh đối tượng Person với các giá trị cho sẵn.
        /// </summary>
        /// <param name="Name"></param>
        /// <param name="Age"></param>
        public Person(string Name, int Age)
        {
            this.Name = Name;
            this.Age = Age;
        }

        /// <summary>
        /// Override phương thức ToString để khi cần có thể in thông tin của object ra cho nhanh.
        /// </summary>
        /// <returns></returns>
        public override string ToString()
        {
            return "Name: " + name + " | Age: " + age;
        }
    }

Tiếp theo ta định nghĩa 1 lớp kế thừa interface ICompare override lại phương thức Compare trong interface này. Hàm Compare sẽ so sánh dựa trên thuộc tính tuổi tăng dần.

 public class SortPersons : IComparer
    {
        public int Compare(object x, object y)
        {
            // Ép kiểu 2 object truyền vào về Person.
            Person p1 = x as Person;
            Person p2 = y as Person;

            /*
             * Vì có thể 2 object truyền vào không phải Person khi đó ta không thể so sánh được.
             * Trường hợp này tốt nhất ta nên ném ra lỗi để lập trình viên sửa chữa.
             * Chi tiết về exception sẽ được trình bày ở những bài học sau.
             */
            if (p1 == null || p2 == null)
            {
                throw new InvalidOperationException();
            }
            else
            {
                /*
                 * Khi dữ liệu đã ok thì ta thực hiện so sánh và trả về các giá trị 1 0 -1 tương ứng
                 * lớn hơn, bằng, bé hơn.
                 */
                if (p1.Age > p2.Age)
                {
                    return 1;
                }
                else if (p1.Age == p2.Age)
                {
                    return 0;
                }
                else
                {
                    return -1;
                }
            }
        }
    }

Cuối cùng là chương trình chính ta thử tạo 1 ArrayList và thêm 1 vài đối tượng Person vào sau đó gọi hàm Sort() và xem kết quả.

            // Tạo 1 danh sách kiểu ArrayList rỗng
            ArrayList arrPersons = new ArrayList();

            // Thêm 3 Person vào danh sách
            arrPersons.Add(new Person("Nguyen Van A", 18));
            arrPersons.Add(new Person("Nguyen Van B", 25));
            arrPersons.Add(new Person("Nguyen Van C", 20));

            // In thử danh sách Person ban đầu ra.
            Console.WriteLine("Danh sach Person ban dau: ");
            foreach (Person item in arrPersons)
            {
                Console.WriteLine(item.ToString());
            }

            /* 
             * Thực hiện sắp xếp danh sách Person theo tiêu chí đã được định nghĩa 
             * trong phương thức Compare của lớp SortPerson (tuổi tăng dần).
             */
            arrPersons.Sort(new SortPersons());

            // In danh sách Person đã được sắp xếp ra màn hình.
            Console.WriteLine();
            Console.WriteLine("Danh sach Person da duoc sap xep theo tuoi tang dan: ");
            foreach (Person item in arrPersons)
            {
                Console.WriteLine(item.ToString());
            }

Kết quả: Danh sách đã được sắp xếp theo tuổi tăng dần.

Tương tự các hoàn toàn có thể định nghĩa cách so sánh phức tạp hơn như thế nữa…


Kết luận

Qua bài này chúng ta đã nắm được:

  • ArrayList là gì?
  • Một số thuộc tính và phương thức hỗ trợ sẵn trong ArrayList.

Bài học sau chúng ta sẽ cùng tìm hiểu về HASHTABLE TRONG C#.

Cảm ơn các bạn đã theo dõi bài viết. Hãy để lại bình luận hoặc góp ý của mình để phát triển bài viết tốt hơn. Đừng quên “Luyện tập – Thử thách – Không ngại khó”.


Tài liệu 

Nhằm phục vụ mục đích học tập Offline của cộng đồng, Kteam hỗ trợ tính năng lưu trữ nội dung bài học ArrayList trong C# dưới dạng file PDF trong link bên dưới.

Ngoài ra, bạn cũng có thể tìm thấy các tài liệu được đóng góp từ cộng đồng ở mục TÀI LIỆU trên thư viện Howkteam.com

Đừng quên like hoặc +1 Google để ủng hộ Kteam và tác giả nhé! 


Thảo luận

Nếu bạn có bất kỳ khó khăn hay thắc mắc gì về khóa học, đừng ngần ngại đặt câu hỏi trong phần BÌNH LUẬN bên dưới hoặc trong mục HỎI & ĐÁP trên thư viện Howkteam.com để nhận được sự hỗ trợ từ cộng đồng. 

 


Thảo luận

Nếu bạn có bất kỳ khó khăn hay thắc mắc gì về khóa học, đừng ngần ngại đặt câu hỏi trong phần BÌNH LUẬN bên dưới hoặc trong mục HỎI & ĐÁP trên thư viện Howkteam.com để nhận được sự hỗ trợ từ cộng đồng.

Nội dung bài viết

Tác giả

Khóa học

Khóa học lập trình C# nâng cao

Khóa học lập trình C# nâng cao

Đánh giá

mocmeow đã đánh giá 02:14 16-04-2019

Trọng Nghĩa đã đánh giá 18:47 09-04-2019

Bình luận

Để bình luận, bạn cần đăng nhập bằng tài khoản Howkteam.

Đăng nhập
agrdino đã bình luận 10:08 04-09-2019

Ad cho em thắc mắc chỗ:

.Sort( new comparer){}

Ý nghĩa từ khóa "new" trong trường hợp là gì và nó được sử dụng như thế nào ạ? Nếu không có từ khóa "new" thì hàm Sort có báo lỗi không ạ? Hay vẫn sort được nhưng không như ý muốn?

Em cảm ơn!

boruto6677 đã bình luận 21:22 03-09-2019

Ad có thể chỉ thêm cho e về từ khóa as được ko ạ..

 

boruto6677 đã bình luận 21:21 03-09-2019

Ad ơi e xem trong bài override là override cần phải có virual hoặc abtract class thì mới sử dụng được mà ở trong ví dụ trên e thấy ko có virual hay abtract class mà tại sao dùng được ạ? 

agrdino đã bình luận 20:32 29-08-2019

AD check lỗi và cho em giải pháp fix với ạ.

code nhằm quản lý danh sách sinh viên, gồm nhập và xuất. nhưng khi nhập thông tin sẽ bị #outofrange ở case 1 case 2 case 3 mà không rõ lý do.

em sử dụng VS pro 2019

using System;
using System.Collections.Generic;

namespace BT.QlySV
{
    public class Program
    {
        public List<infomation> students = new List<infomation>();  //nguyên bảng gồm nhiều hàng students

        public class infomation                                     //định nghĩa kiểu dữ liệu
        {
            public List<string> item = new List<string>();          //mỗi students có nhiều item 
        }
        public List<infomation> GetList(int total)
        {
            var each = new List<infomation>();                      //xét từng học sinh
            for (int i = 1; i <= total; i++)
            {
                for (int j = 1; j <= 3; j++)                        //1 là mã số, 2 là tên, 3 là điểm
                {
                    switch (j)
                    {
                        case 1:
                            {
                                Console.Write("Maso: ");
                                each[i].item.Add(Console.ReadLine());
                                break;
                            }
                        case 2:
                            {
                                Console.Write("\t Ten: ");
                                each[i].item.Add(Console.ReadLine());
                                break;
                            }
                        case 3:
                            {
                                Console.Write("\t Diem: ");
                                each[i].item.Add(Console.ReadLine());
                                break;
                            }
                    }
                }
            }
            return students = each;
        }
        public void print(int nom)
        {
            Program print = new Program();
            foreach (var each in print.students)
            {
                for (int i = 0; i < students.Count; i++)
                {
                    if (i == nom)
                    {
                        for (int j = 0; j < each.item.Count; j++)
                        {
                            Console.Write(each.item[j]);
                            Console.WriteLine();
                        }
                    }
                    else
                    {
                        Console.Write("Khong tim thay du lieu!");
                    }
                }
                
            }
        } 
        static void Main(string[] args)
        {
            Program Input = new Program();
            Console.Write("Nhap tong: ");
            int total = int.Parse(Console.ReadLine());
            Input.GetList(total);
            Console.Write("Nhap maso: ");
            int nom = int.Parse(Console.ReadLine());
            Input.print(nom);
            Console.ReadKey();

        }
    }
}
 

Thành Ý đã bình luận 08:51 09-12-2018

 

arrPersons.Add(new Person("Nguyen Van A", 18));

arrPersons.Add(new Person("Nguyen Van B", 25));

arrPersons.Add(new Person("Nguyen Van C", 20)); 

Person bị lỗi a ơi

 

Không có video.