C#表达式

表达式,把变量、字面值与运算符组合起来,就创建表达式,是计算的基本构件。
字面值:是源代码中键入的数字、字符串,表示指定类型的值。常用有几种:整数、实数、字符、字符串

整数字面量【也能使用十六进制表式】:

    • 123   //整形
    • 123L   //长整形
    • 123U   //无符号整形
    • 123UL   //无符号长整形

实数字面量:

    • 1.5F   //float类型
    • 1.5   //double类型
    • 1.5M   //decimal类型

字符字面量:

    • 'a'   //char类型
    • '\n'   //简单转义序列:反斜杠+单个字符
    • '\x0061'  //十六进制转义序列
    • '\u005a'  //Unicode转义序列

字符串字面量:

  • "Hi There";
  • "Val\t5,val\t10";
  • @"C:\Program Files\Microsoft";

注:字符串以@为前缀,在双引号中的所有内容,包括通常被认为是转义序列的内容,被严格按字符串中列出的打印。

运算符,大致分为3类。

  • 一元运算符,处理一个操作数
  • 二元运算符,处理两个操作数【大部分】
  • 三元运算符,处理三个操作数

数字运算符

运算符  类别 示例表达式 结果
+ 二元 var1=var2+var3 var1的值是var2与var3之和
- 二元 var1=var2-var3 var1的值是var2与var3之差
* 二元 var1=var2*var3 var1的值是var2与var3之积
/ 二元 var1=var2/var3 var1的值是var2除以var3所得值
% 二元 var1=var2%var3 var1的值是var2除以var3所得余数
+ 一元   var1=+var2 var1的值等于var2的值
- 一元 var1=-var2 var1的值等于var2的值乘以-1

字符串运算符

运算符 类型 示例表达式 结果
+ 二元   var1=var2+var3 var1的值是存储在var2和var3中的两个字符串连接值

递增和递减运算符

  • ++总是使用操作数加1
  • --总是使用操作数减1
运算符 类型 示例表达式 结果
++ 一元   var1=++var2; var1的值是var2+1,var2递增1
-- 一元 var1=--var2; var1的值是var2-1,var2递减1
++   一元 var1=var2++;   var1的值是var2,var2递增1
-- 一元 var1=var2--; var1的值是var2,var2递减1

赋值运算符

运算符 类型 示例表达式 结果
= 二元 var1=var2;   var1被赋予var2的值
+= 二元 var1+=var2;   var1被赋予var1与var2的和
-= 二元   var1-=var2; var1被赋予var1与var2之差
*=   二元 var1*=var2; var1被赋予var1与var2乘积
/= 二元 var1/=var2; var1被赋予var1与var2相除所得的结果
%= 二元 var1%=var2; var1被赋予var1与var2相除所得的余数

运算符优先级

优先级 运算符

++,--(用作前缀);+,-(一元)
*,/,%
+,-
=,*=,/=,%=,+=,-=
++,--(用作后缀)

注:用括号可用于重写优先级顺序。

C#入门笔记3 表达式及运算符的更多相关文章

  1. C#入门笔记3 表达式及运算符2

    关系运算符,也称布尔比较运算符 注:var1为bool类型,var2与var3可以是其它类型.[数据类型看下一节] 运算符 类别 示例表达式 结果说明 == 二元 var1=var2==var3 如果 ...

  2. Python入门笔记(12):表达式和语句

    一.Python语句 if语句.else语句.elif语句.条件表达式.while语句.for语句.break语句.continue语句.pass语句.Iterators(迭代器).列表解析 二.常用 ...

  3. C Primer Plus学习笔记(四)- 运算符、表达式和语句

    基本运算符 赋值运算符:= 在C语言中,=不是“相等”,而是赋值运算符,把左边的值赋给右边的变量 a = 2018; //把值2018赋给变量a 赋值表达式语句的目的是把值储存到内存位置上,用于储存值 ...

  4. Ruby入门笔记

    Ruby入门笔记 一切皆为对象 “Hello”.length 方法 定义:def开头 end结尾 命名一般采用下划线分隔单词

  5. React.js入门笔记

    # React.js入门笔记 核心提示 这是本人学习react.js的第一篇入门笔记,估计也会是该系列涵盖内容最多的笔记,主要内容来自英文官方文档的快速上手部分和阮一峰博客教程.当然,还有我自己尝试的 ...

  6. MySQL入门笔记(一)

    一.数据类型 1. 整型 2. 浮点型 3. 字符型 4. 日期时间型 二.数据库操作 1. 创建库 CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_nam ...

  7. MySQL入门笔记(二)

    MySQL的数据类型.数据库操作.针对单表的操作以及简单的记录操作可参考:MySQL入门笔记(一) 五.子查询   子查询可简单地理解为查询中的查询,即子查询外部必然还有一层查询,并且这里的查询并非仅 ...

  8. 「Android 开发」入门笔记

    「Android 开发」入门笔记(界面编程篇) ------每日摘要------ DAY-1: 学习笔记: Android应用结构分析 界面编程与视图(View)组件 布局管理器 问题整理: Andr ...

  9. awk 新手入门笔记

    转自:http://www.habadog.com/2011/05/22/awk-freshman-handbook/ awk新手入门笔记 @作者 : habadog@邮箱 : habadog1203 ...

随机推荐

  1. Linux-内存进程和软件安装

    1 swap分区 swapon -s 查看swap分区 mkswap 某分区挂载点 swapon -a 分区 激活该swap swapoff 挂载点 取消swap分区 2 内存 free 查看内存空间 ...

  2. boost replace_if replace_all_regex_copy用法

    #include <boost/algorithm/string.hpp> // for is_any_of #include <boost/range/algorithm/repl ...

  3. Can't locate Log/Dispatch.pm in @INC /Makefile out-of-date with respect to Makefile.PL

    mha check的时候报错问题解决:   # masterha_check_ssh --conf=/data/mha/app1.cnf Can't locate Log/Dispatch.pm in ...

  4. CTSC2012 熟悉的文章

    传送门 首先很容易想到对于所有的模式串建出广义后缀自动机,之后对于我们每一个要检查的文本串,先在SAM上跑,计算出来每一个位置能匹配到的最远的位置是多少.(就是当前点减去匹配长度) 之后--考虑DP- ...

  5. vue 路由监听

    发现网上其实有很多种答案,但是测试之后发现很多都不行,或者写的不完整. 一.在app.vue组件内,增加监听$route,如下: watch: { $route(to, from) { console ...

  6. 洛谷P1073最优贸易——双向取值

    题目:https://www.luogu.org/problemnew/show/P1073 由于任何城市都可以多次经过,所以可以随便走,也就不用太在意有向边和无向边,把无向边当做两条有向边处理: 根 ...

  7. Lsyncd搭建同步镜像-用Lsyncd实现本地和远程服务器之间实时同步

    Lysncd即Live Syncing Daemon,它是开源的数据实时同步工具(后台进程),基于inotify和rsync. lsyncd会密切监测本地服务器上的参照目录,当发现目录下有文件或目录变 ...

  8. 经典分析--HTTP协议

    Web服务器,浏览器,代理服务器 当我们打开浏览器,在地址栏中输入URL,然后我们就看到了网页. 原理是怎样的呢? 实际上我们输入URL后,我们的浏览器给Web服务器发送了一个Request, Web ...

  9. AngularJS系统学习之Scope(作用域)

    本文出自:https://www.w3ctech.com/topic/1611 看完了没怎么懂,  也许是和别人 原文作者: Nicolas Bhttps://www.w3ctech.com/topi ...

  10. idea创建vue项目,Terminal安装npm的淘宝镜像:'npm' 不是内部或外部命令,也不是可运行的程序 或批处理文件。

    原因: 安装node.js时,不是默认路径安装,环境变量找不到npm,需要改环境变量配置: 原下: 找到安装node.js的安装路径: 改后: 成功: npm i -g cnpm --registry ...