Thông báo

Collapse
No announcement yet.

Hàm tạo trễ delay

Collapse
X
 
  • Lọc
  • Giờ
  • Show
Clear All
new posts

  • Hàm tạo trễ delay

    void delay(unsigned int ms)//hàm này tạo độ trễ thời gian, dơn vị là ms
    {
    unsigned int i;
    unsigned char j;//khai báo kiểu "char"mỗi biến chỉ chiếm 1 byte
    for(i=0;i<ms;i++)
    for(j=0;j<120;j++);
    }

    Khác j` so với đoạn code:

    void delay(unsigned int ms)
    {
    unsigned int i;
    for (i=0;i<ms;i++);
    }

    Cách nào tốt hơn ạ?
    Thanks!

  • #2
    void delay(unsigned int ms)//hàm này tạo độ trễ thời gian, dơn vị là ms
    {
    unsigned int i;
    unsigned char j;//khai báo kiểu "char"mỗi biến chỉ chiếm 1 byte
    for(i=0;i<ms;i++)
    for(j=0;j<120;j++);
    }

    Khác j` so với đoạn code:

    void delay(unsigned int ms)
    {
    unsigned int i;
    for (i=0;i<ms;i++);
    }

    Cách nào tốt hơn ạ?
    Thanks!
    Dear nvt8xm!
    Điểm khác nhau ở 2 chương trình này là ở độ trễ thời gian tối đa mà chương trình có thể tạo ra.
    - Ở chương trình thứ nhất biến i kiểu int --> nó có thể nhận giá trị tối đa đến 65535. biến j kiểu char --> nó có thể nhận giá trị tối đa đến 255. Chương trình dùng 2 vòng lặp lồng nhau --> thời gian trễ tối đa của chương trình có thể được 255*65535*(thời gian tăng biến đếm)
    - Ở chương trình thứ 2, chỉ có 1 biến kiểu int, và 1 vòng lặp for --> thời gian trễ tối đa là 65535*(thời gian tăng biến đếm)

    Rõ ràng chương trình đầu tiên có thể tạo độ trễ thời gian lớn hơn chương trình trước rất nhiều.

    - Trong hai chương trình trên không có chương trình nào tốt hơn chương trình nào cả. Tùy vào độ trễ thời gian yêu cầu mà sử dụng cho phù hợp thôi.

    Thân ái!
    For a better world

    Comment


    • #3
      Với cùng 1 giá trị biến ms đưa vào 2 hàm nói trên thì chương trình thứ nhất còn phải lặp 120 lần nữa mới xong hàm delay (lâu gấp 120 lần - Do biến j bị giới hạn <120) so với hàm thứ 2.

      Comment


      • #4
        Nguyên văn bởi Multi System Xem bài viết
        Với cùng 1 giá trị biến ms đưa vào 2 hàm nói trên thì chương trình thứ nhất còn phải lặp 120 lần nữa mới xong hàm delay (lâu gấp 120 lần - Do biến j bị giới hạn <120) so với hàm thứ 2.
        Đồng ý với ý kiến của bác!
        Tuy vậy mình xin bổ sung thêm tí là VĐK mới chỉ có CPU 8bit nên khai báo int (16bit) thì trong tất cả các phép toán nó cũng phải quy đổi về 8bit. Do vậy có thể xử lí một phép tính int sẽ lâu hơn rất nhiều so với xử lí char. Lâu hơn là bao nhiêu thì bạn nào biết up lên phát cho mọi người xem!
        GTH sản xuất mạch in PCB 1 mặt:
        -phủ xanh: 40.000 đ/dm2
        -không phủ xanh: 30.000 đ/dm2
        -Cung cấp mực cảm quang để làm mạch in
        email:

        Comment


        • #5
          Cái này chủ yếu hiểu theo nghĩa tương đối thôi.
          Muốn biết chính xác bao nhiêu thì chịu khó ngồi Debug, chờ mỏi răng luôn (vì vừa chờ vừa nhai kẹo cao su)

          Comment


          • #6
            Cám ơn tất cả các bác, em hiểu rồi ạ

            Comment

            Về tác giả

            Collapse

            nvt8xm Tìm hiểu thêm về nvt8xm

            Bài viết mới nhất

            Collapse

            Đang tải...
            X