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:
- CẤU TRÚC LỆNH CỦA C# VIẾT TRÊN NỀN CONSOLE APPLICATION.
- CẤU TRÚC NHẬP XUẤT CỦA C# TRÊN NỀN CONSOLE APPLICATION.
- BIẾN & KIỂU DỮ LIỆU trong C#.
Trong bài học này, chúng ta sẽ cùng tìm hiểu các vấn đề:
- Toán tử là gì? Có mấy loại toán tử?
- Cú pháp và ý nghĩa của từng toán tử.
- Độ ưu tiên của toán tử.
- Ví dụ chương trình sử dụng một số toán tử.
Toán tử là gì?
Toán tử được định nghĩa như sau:
- Là một công cụ để thao tác với dữ liệu.
- Một toán tử là một ký hiệu dùng để đại diện cho một thao tác cụ thể được thực hiện trên dữ liệu.
Có 6 loại toán tử cơ bản:
- Toán tử toán học.
- Toán tử quan hệ.
- Toán tử logic.
- Toán tử khởi tạo và gán.
- Toán tử so sánh trên bit.
- Toán tử khác.
Cú pháp và ý nghĩa của từng toán tử
Toán tử toán học
Giả sử biến a có giá trị là 10 biến b có giá trị là 9
Toán tử |
Mô tả |
Ví dụ |
+ |
Thực hiện cộng hai toán hạng |
a + b kết quả bằng 19 |
- |
Thực hiện trừ hai toán hạng |
a - b kết quả bằng 1 |
* |
Thực hiện nhân hai toán hạng |
a * b kết quả bằng 90 |
/ |
Thực hiện chia lấy phần nguyên hai toán hạng nếu 2 toán hạng là số nguyên. Ngược lại thì thực hiện chia bình thường |
a / b kết quả bằng 1 |
% |
Thực hiện chia lấy dư |
a%b kết quả bằng 1 |
++ |
Tăng giá trị lên 1 đơn vị |
a++ kết quả bằng 11 |
-- |
Giảm giá trị xuống 1 đơn vị |
a-- kết quả bằng 9 |
Lưu ý: đối với toán tử ++ và -- cần phần biệt a++ và ++a (hoặc a-- và --a):
- a++: là sử dụng giá trị của biến a để thực hiện biểu thức trước rồi mới thực hiện tăng lên 1 đơn vị. Tương tự cho a--.
- ++a: là tăng giá trị biến a lên 1 đơn vị rồi mới sử dụng biến a để thực hiện biểu thức. Tương tự cho --a.
Toán tử quan hệ
Giả sử biến a có giá trị bằng 10 và biến b có giá trị bằng 9:
Toán tử |
Mô tả |
Ví dụ |
== |
So sánh 2 toán hạng có bằng nhau hay không. Nếu bằng thì trả về true nếu không bằng thì trả về false |
a == b sẽ trả về false |
!= |
So sánh 2 toán hạng có bằng nhau hay không. Nếu không bằng thì trả về true nếu bằng thì trả về false |
a != b sẽ trả về true |
> |
So sánh 2 toán hạng bên trái có lớn hơn toán hạng bên phải hay không. Nếu lớn hơn thì trả về true nếu không lớn hơn thì trả về false |
a > b sẽ trả về true |
< |
So sánh 2 toán hạng bên trái có nhỏ hơn toán hạng bên phải hay không. Nếu nhỏ hơn thì trả về true nếu không nhỏ hơn thì trả về false |
a < b sẽ trả về false |
>= |
So sánh 2 toán hạng bên trái có lớn hơn hoặc bằng toán hạng bên phải hay không. Nếu lớn hơn hoặc bằng thì trả về true nếu nhỏ hơn thì trả về false |
a >= b sẽ trả về true |
<= |
So sánh 2 toán hạng có nhỏ hơn hoặc bằng hay không. Nếu nhỏ hơn hoặc bằng thì trả về true nếu lớn hơn thì trả về false |
a <= b sẽ trả về false |
Lưu ý:
- Các toán tử quan hệ này chỉ áp dụng cho số hoặc ký tự.
- Hai toán hạng hai bên phải cùng loại (cùng là số hoặc cùng là ký tự).
- Bản chất của việc so sánh 2 ký tự với nhau là so sánh mã ASCII của các ký tự đó.
- Ví dụ: so sánh ‘A’ và ‘B’ bản chất là so sánh số 65 với 66.
- Không nên sử dụng các toán tử trên để so sánh các chuỗi với nhau vì bản chất việc so sánh chuỗi là so sánh từng ký tự tương ứng với nhau mà so sánh ký tự là so sánh mã ASCII của ký tự đó như vậy ký tự ‘K’ sẽ khác ký tự ‘k’. Để so sánh hai chuỗi người ta thường dùng hàm so sánh chuỗi đã được hỗ trợ sẵn (sẽ tìm hiểu ở những bài tiếp theo).
Toán tử logic
Giả sử mệnh đề A là đúng và mệnh đề B là sai:
Toán tử |
Mô tả |
Ví dụ |
&& |
Hay còn gọi là toán tử logic AND (và). Trả về true nếu tất cả toán hạng đều mang giá trị true. Và trả về false nếu có ít nhất 1 toán hạng mang giá trị false. |
A && B kết quả là false |
|| |
Hay còn gọi là toán tử logic OR (hoặc). Trả về true nếu có ít nhất 1 toán hạng mang giá trị true. Và trả về false nếu tất cả toán hạng đều mang giá trị false. |
A || B kết quả là true. |
! |
Hay còn gọi là toán tử logic NOT (phủ định). Có chức năng đảo ngược trạng thái logic của toán hạng. Nếu toán hạng đang mang giá trị true thì kết quả sẽ là false và ngược lại. |
!A kết quả là false |
Lưu ý:
- Các toán tử && và || có thể áp dụng đồng thời nhiều toán hạng, ví dụ như: A && B && C || D || K (Thứ tự thực hiện sẽ được trình bày ở phần sau).
- Các toán hạng trong biểu thức chứa toán tử logic phải trả về true hoặc false.
Toán tử khởi tạo và gán
Toán tử khởi tạo và gán thường được sử dụng nhằm mục đích lưu lại giá trị cho một biến nào đó. Một số toán tử khởi tạo và gán hay được sử dụng:
Toán tử |
Mô tả |
Ví dụ |
= |
Gán giá trị của toán hạng bên phải cho toán hạng bên trái. |
K = 10 sẽ gán 10 cho biến K |
+= |
Lấy toán hạng bên trái cộng toán hạng bên phải sau đó gán kết quả lại cho toán hạng bên trái. |
K += 1 tương đương với K = K + 1 |
-= |
Lấy toán hạng bên trái trừ toán hạng bên phải sau đó gán kết quả lại cho toán hạng bên trái. |
K -= 1 tương đương với K = K – 1 |
*= |
Lấy toán hạng bên trái nhân toán hạng bên phải sau đó gán kết quả lại cho toán hạng bên trái. |
K *= 1 tương đương với K = K * 1 |
/= |
Lấy toán hạng bên trái chia lấy phần nguyên với toán hạng bên phải sau đó gán kết quả lại cho toán hạng bên trái. |
K /= 1 tương đương với K = K / 1 |
%= |
Lấy toán hạng bên trái chia lấy dư với toán hạng bên phải sau đó gán kết quả lại cho toán hạng bên trái. |
K %= 1 tương đương với K = K % 1 |
Một số lưu ý khi sử dụng các toán tử trên:
- Toán tử bên trái thường là một biến, còn toán tử bên phải có thể là biến có thể là biểu thức đều được.
- Một phép toán gán hoặc khởi tạo có thể được sử dụng như là toán hạng bên phải cho một phép gán hoặc khởi tạo khác. Ví dụ:
Toán tử so sánh trên bit
Các toán tử so sánh trên bit cũng ít gặp nên mình chỉ giới thiệu qua cho các bạn tham khảo thôi chứ chúng ta không giới thiệu rõ phần này.
Giả sử a có giá trị bằng 10 và b có giá trị bằng 9. Giá trị biến a đổi ra nhị phân là 1010 và giá trị biến b đổi ra nhị phân là 1001
Toán tử |
Mô tả |
Ví dụ |
& |
Sao chép bit 1 tới kết quả nếu nó tồn tại trong cả hai toán hạng tại vị trí tương ứng, ngược lại thì bit kết quả bằng 0 |
a&b sẽ cho kết quả là 1000 tương đương với số 8 trong hệ thập phân |
| |
Sao chép bit 1 tới kết quả nếu nó tồn tại ở một trong hai toán hạng tại vị trí tương ứng, ngược lại thì bit kết quả bằng 0 |
a|b sẽ cho kết quả 1011 tương đương với số 11 trong hệ thập phân |
^ |
Sao chép bit 1 tới kết quả nếu nó chỉ tồn tại ở một toán hạng tại vị trí tương ứng, ngược lại thì bit kết quả bằng 0 |
a^b sẽ cho kết quả 0011 tương đương với số 3 trong hệ thập phân |
~ |
Dùng để đảo bit 0 thành 1 và ngược lại 1 thành 0 |
~a sẽ cho kết quả 0101 |
<< |
Dịch trái n bit. Giá trị toán hạng bên trái sẽ được dịch trái n bit với n được xác định bởi toán hạng bên phải |
a<<2 sẽ cho kết quả 101000 |
>> |
Dịch phải n bit. Giá trị toán hạng bên trái sẽ được dịch phải n bit với n được xác định bởi toán hạng bên phải |
a>>2 sẽ cho kết quả 0010 |
Toán tử khác
Ngoài những toán tử đã giới thiệu ở trên chúng ta vẫn còn nhiều toán tử khác cũng hay sử dụng:
Toán tử |
Mô tả |
Ví dụ |
sizeof() |
Trả về kích cỡ của một kiểu dữ liệu |
sizeof(int) sẽ trả về 4 |
typeof() |
Trả về kiểu của một lớp (khái niệm về lớp sẽ được trình bày trong bài CLASS TRONG C#) |
typeof(string) sẽ trả về System.String |
new |
Cấp phát vùng nhớ mới, áp dụng cho kiểu dữ liệu tham chiếu |
DateTime dt = new DateTime() (sẽ được trình bày chi tiết trong STRUCT TRONG C#) |
is |
Xác định đối tượng có phải là một kiểu cụ thể nào đó hay không. Nếu đúng sẽ trả về true ngược lại trả về false |
Sẽ được trình bày trong những bài sau |
as |
Ép kiểu mà không gây ra lỗi. Nếu ép kiểu không thành công sẽ trả về null |
Sẽ được trình bày chi tiết trong ÉP KIỂU TRONG C# |
? : |
Được gọi là toán tử 3 ngôi. Tương đương với cấu trúc điều kiện (sẽ được trình bày ở bài CẤU TRÚC RẼ NHÁNH TRONG C#) Cú pháp:
Ý nghĩa: trả về toán hạng 2 nếu toán hạng 1 là true và ngược lại trả về toán hạng 3 |
(1 < 2) ? 1 : 0 kết quả là 1 vì toán hạng 1 là (1 < 2) là đúng nên trả về toán hạng 2 là 1 |
, |
Sử dụng toán tử “,” để kết nối nhiều biểu thức lại với nhau. Cú pháp:
Ý nghĩa: Duyệt qua biểu thức 1 sau đó duyệt qua biểu thức 2 và trả về giá trị của biểu thức 2 |
(t = 5, 2) sẽ duyệt qua biểu thức 1 là t = 5, thực hiện gán 5 cho t sau đó duyệt qua biểu thức 2 là 2, cuối cùng trả về giá trị là 2 |
Độ ưu tiên của toán tử
Độ ưu tiên của các toán tử biểu thị cho việc toán tử nào được ưu tiên thực hiện trước trong câu lệnh. Độ ưu tiên được tóm tắt ở bảng sau:
Mức |
Toán tử |
Thứ tự |
|||||||||
Cao nhất |
() [] . |
Trái sang phải |
|||||||||
|
+ - |
++ -- |
! ~ |
new |
sizeof() typeof() |
Phải sang trái |
|||||
* |
/ |
% |
Trái sang phải |
||||||||
<< |
>> |
Trái sang phải |
|||||||||
< |
<= |
> |
>= |
Trái sang phải |
|||||||
== |
!= |
Trái sang phải |
|||||||||
& |
^ |
| |
Trái sang phải |
||||||||
&& |
|| |
Trái sang phải |
|||||||||
? : |
|
||||||||||
= |
+= -= |
*= /= |
%= |
Phải sang trái |
|||||||
Thấp nhất |
, |
Bảng thống kê trên chỉ thể hiện những toán tử chúng ta đã học, ngoài ra vẫn còn nhiều toán tử khác những ít khi sử dụng nên không đề cập đến.
Từ bảng trên ta có thể rút ra được 1 kinh nghiệm đó là nếu muốn biểu thức nào được thực hiện trước ta chỉ cần nhóm chúng vào cặp ngoặc tròn ( ) là được!
Ví dụ chương trình sử dụng một số toán tử
Ví dụ : Kết hợp các phép toán để viết chương trình kiểm tra số nhập vào là số chẵn số lẻ:
Đầu tiên ta có 3 biến:
- strSoNguyen: Chứa dữ liệu nhập vào từ bàn phím. Vì dữ liệu nhập vào từ bàn phím mặc định là dạng chuỗi nên cần biến kiểu chuỗi để chứa giá trị.
- SoNguyen: Chứa dữ liệu nhập vào từ bàn phím ở dạng số. Từ dữ liệu dạng chuỗi của biến strSoNguyen ta ép kiểu sang kiểu số để dễ xử lý (chi tiết về ép kiểu sẽ được trình bày ở bài ÉP KIỂU TRONG C#)
- KetQua: Chứa kết quả kiểm tra số vừa nhập là chẵn hay lẻ. Kết quả này ở dạng chuỗi để có thể in ra màn hình luôn.
Code:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace Bai_06_01
{
class Program
{
static void Main(string[] args)
{
string StrSoNguyen;
int SoNguyen;
string StrKQ;
Console.Write("Nhap so nguyen : ");
StrSoNguyen = Console.ReadLine();
SoNguyen = Int32.Parse(StrSoNguyen); // chuyen sang so nguyen
StrKQ = (SoNguyen % 2 == 0) ? "So Chan" : "So Le";
Console.WriteLine("{0} la {1}", SoNguyen, StrKQ);
Console.ReadKey();
}
}
}
KQ:
Kết luận
Nội dung bài này giúp các bạn nắm được:
- Khái niệm về toán tử và các loại toán tử.
- Cú pháp và ý nghĩa của từng toán tử.
- Độ ưu tiên của các toán tử.
- Ví dụ chương trình sử dụng một số toán tử.
Bài học sau chúng ta sẽ cùng tìm hiểu một khái niệm tiếp theo đó là HẰNG TRONG C#