Chú ý khi làm việc với floating point
TIL
496
programming
62
Ruby
106
White

linhnv viết ngày 05/05/2016

Khi làm việc đôi khi ta phải so sánh 2 số thập phân mà nếu không để ý sẽ dẫn đến kết quả sai lệch ngoài dự đoán như trong ví dụ dưới đây.

VD:

0.1 + 0.2 == 0.3
#=> false

Giải thích:

Bản chất là do máy tính ko thể biểu diễn chính xác hầu hết các số thập phân. Do đó khi code được biên dịch thì các số này đc làm tròn về giá trị gần nhất với nó (ở dạng binary).

Tips:

Vậy làm thế nào để so sánh đc 2 số dạng này?

  • Dùng 1 kiểu dữ liệu đặc biệt (ruby: BigDecimal)
  • Làm tròn các số thập phân muốn so sánh về cùng 1 số dạng có số chữ số sau giống phẩy giống nhau

Link:

http://floating-point-gui.de/basic/

Bình luận


White
{{ comment.user.name }}
Bỏ hay Hay
{{comment.like_count}}
Male avatar
{{ comment_error }}
Hủy
   

Hiển thị thử

Chỉnh sửa

White

linhnv

1 bài viết.
0 người follow
Kipalog
{{userFollowed ? 'Following' : 'Follow'}}
Bài viết liên quan
White
49 21
Luận về comment code (Phong cách kiếm hiệp) Comment code luôn là vấn đề gây tranh cãi sứt đầu mẻ trán trong giới võ lâm. Xưa kia, thuở còn mài đít...
Huy Hoàng Phạm viết hơn 2 năm trước
49 21
White
10 0
Không gì đẹp bằng nụ cười khi đôi mắt e lệ nhìn xuống. Victor Hugo Các bạn có thể đọc bài viết gốc tại (Link) Tò mò khi tìm hiểu hoạt động của ...
Đào Văn Hùng viết 3 tháng trước
10 0
{{like_count}}

kipalog

{{ comment_count }}

bình luận

{{liked ? "Đã kipalog" : "Kipalog"}}


White
{{userFollowed ? 'Following' : 'Follow'}}
1 bài viết.
0 người follow

 Đầu mục bài viết

Vẫn còn nữa! x

Kipalog vẫn còn rất nhiều bài viết hay và chủ đề thú vị chờ bạn khám phá!