当前位置: 首页 > news >正文

java 运算符,流程控制语句,键盘录入

1.比较运算符

public static void main(String args[])
{
    int x = 3;
    int y = 4;
    int z = 5;
    System.out.println(x > y);
    System.out.println(x < y);
    System.out.println(x == y);
    System.out.println(x + y > x + z);
    System.out.println(x >= y);
    }
    基本的比较运算符便是  大于,小于,等于,大于等于,小于等于, 输出结果也是看是否符合比较,符合便输出true,不符合编书处flase;

2.赋值运算符

public static void main(String args[])
{
    int a = 20;
    System.out.println(a);
    int b = 10;
    System.out.println(b);
    System.out.println("----------------");
    int n;
    int m = n = 10;
    System.out.println((newStringBuilder("m:")).append(m).append(",n:").append(n).toString());
    System.out.println("-----------------");
    int y = 10;
    y += 20;
    System.out.println((new StringBuilder("y:")).append(y).toString());
}   

赋值运算符“=”
注意赋值时和其他运算符之间的优先级;
+++++++
上述代码中的
(1).  new StringBuilder("内容 ")为匿名创建对象,而对象的内容便是双引号中的内容;
(2). append(" ")是附加的意思,append方法中如果是自定义变量,则不需要加双引号,如果是字符串,则加双引号;

(3). toString()这个方法它是一种对象类型,字符串,不可变的,StringBuilder带有缓冲区,通过它,可改变字符串的这个不足的地方,如是我们用“+”来拼字符串,这个过程中,会创建很多个字符串对象,用StringBuilder,它就利用缓冲作用来完成这种工作,它与stringbuffer很类似,只是,它是线程非安全的,效率要比stringbuffer高些 ,在用append()附加字符串,最后最好使用toString()方法将其变成一个完整的字符串;

内容扩充:此时可以注意String类型,StringBuffer类型和StringBuilder类型的区别?
<https://zhidao.baidu.com/question/1386767228469012700.html&gt;
<https://zhidao.baidu.com/question/2058150115619791027.html&gt;

3.键盘录入

public static void main(String args[])
{

    Scanner sc = new Scanner(System.in);
    System.out.println("请您输入第一个数据:");
    int num1 = sc.nextInt();
    System.out.println("请您输入第二个数据:");
    int num2 = sc.nextInt();
    int max = num1 <= num2 ? num2 : num1;
    System.out.println((new StringBuilder("您输入的最大值是:")).append(max).toString());
    }

    如上述代码,先创建Scanner对象,创建对象时记得导入Java.util.Scanner包,因为只有导入这个包才可以创建Scanner对象,进而调用方法nextInt()获取键盘录入的内容;
    nextInt()代表获取输入的Int型对象;
    而代码中int max = num1 <= num2 ? num2 : num1;
    ?:其实是一个三目运算符;
    代表的意思是如果符合num1 <= num2,则输出num2,否则输出num1;输出的顺序看num2 : num1;如果想输出最小数,为 int min = num1<=num2?num1:num2;

4.三目运算符
?:三目运算符,比较大小,类似于if(){}else{},如三所示
三目运算符比较两数是否相等时
boolean flag = num1==num2?true:false;
改进后
boolean flag = num1==num2;即可

5.逻辑运算符

&和 | 既是逻辑运算符也是位运算符,而&&和||只是逻辑运算符。

同为逻辑运算符,他们的区别在哪里??
(1)当&与&&同为逻辑运算符时,它们都用于连接两个Boolean类型的表达式,当&和&&的两端表达式同时为真时,表达式的结果为真,只要有一端为假,那么表达式结果为假。从用法上来看,&和&&并没有什么区别,比如我们可以写两个表达式:

          3>5&3>2;       3>5&&3>2;

          两个运算符都可以这么用,但是不同的是,当在判断这个表达式的真或假的时候,两者的判断次数不同;

         当使用&运算符: 计算机在判断表达式的值的时候,先判断3>5 的值为假,然后再判断3>2的结果为真,于是最后的结果是 假&真 为假;

         但是当我们使用&&运算符的时候:计算机先判断3>5 的值为假,此时表达式的结果一定为假,所以计算机就不再往下判断了,判定表达式结果为假。

         逻辑运算符&与&&的区别是:

         & 无论左边结果是什么,右边还是继续运算;

         &&当左边为假,右边不再进行运算。

         但是两者的结果是一样的。

        (2)当|和||的两端表达式同时为假时,表达式的结果为假,只要有一端为真,那么表达式结果为真。

         所以同理,我们可以知道|与||的区别:

         | 无论左边结果是什么,右边还是继续运算;

         ||当左边为真,右边不再进行运算。

         但是两者的结果是一样的。

         所以&&和||是比较高效一些;

                     如代码所示:
                    public static void main(String args[])
{
    int a = 3;
    int b = 4;
    int c = 5;
    System.out.println(a > b & a > c);
    System.out.println(a > b && a > c);
    System.out.println(a < b && a > c);
    System.out.println(a < b && a < c);
    System.out.println("---------------------");
    int x = 3;
    int y = 4;
    boolean b1 = ++x == 3 && y++ == 4;
    System.out.println((new StringBuilder("x:")).append(x).toString());
    System.out.println((new StringBuilder("y:")).append(y).toString());
    System.out.println(b1);
}
输出的前两个虽然结果一样,但是运行绝对不同;

!!!补充++x和x++的含义
++x会在本次运行中使x+1,进行改变;而x++则在本次运行中不改变;
如上述代码;++x==3,则x=4;  y++==4,则y还是4;

代码迷茫症状易错点:boolean b1 = 4&&4;应该为true,可为什么运行结果为false?

其实是x=3,++x与3进行比较为false,所以结果为false;在这里boolean b1 = ++x == 3 && y++ == 4;是个三目运算符,连接的是两个boolean关系的表达式,虽然有&&,但是只能代表&&左边右边分别为一个boolean的表达式;

6.算术运算符

  • 加 -减 *乘 /除 %除 ++ --

    /和%的区别?
    比如 int a = 3 ; int b = 4;
    a/b=0; /代表取整数;
    a%b=3; /代表取余数;

    如果要求出a/b的确切答案,最好定义int(整型)为double(双精度型);如果定义的为int型,如上面运算,则进行强制转换;
    强制转换为double:   ((double)a*1.0d)/(double)b=0.75;
    1.0d代表的对double的生命,不加也不会出错,最好加上,而前面的(double)代表强制转换为double类型;
    
    如代码所示:
    
    public static void main(String args[])

    {

    int x = 3;
    int y = 4;
    int m = x++;
    int n = y--;
    System.out.println((new StringBuilder("x:")).append(x).toString());
    System.out.println((new StringBuilder("y:")).append(y).toString());
    System.out.println((new StringBuilder("m:")).append(m).toString());
    System.out.println((new StringBuilder("n:")).append(n).toString());

    }

    ++x会在本次运行中使x+1,进行改变;而x++则在本次运行中不改变;

    如上述代码;++x==3,则x=4; y++==4,则y还是4;

    则上述代码输出结果为 x:4 y:3 m:3 n:4
    原因是x++ 中x并没有先+,而是先给m赋值,所以m为3,之后x自行加1,则x为4,y同理.

    7.流程控制语句

    (1)顺序结构 从上往下,依次执行
    (2)选择结构 按照不同的选择,执行不同的代码
    (3)循环结构 做一些重复的代码

    if语句

    **格式:
    if(条件){满足条件后的运行语句};(1)
    else if(条件){满足条件后的运行语句};(2)
    else{不满足上述条件的其他所有情况的运行语句};(3)
    上述三行第一行单独是一种格式,第一行和第三行合起来是一种格式,三行一起是一种格式;
    注意点:
    A:比较表达式无论简单还是复杂,结果是boolean类型
    B:if语句控制的语句体如果是一条语句,是可以省略大括号的;如果是多条,不能省略。
    建议:永远不要省略。
    C:一般来说,有左大括号,就没有分号,有分号,就没有左大括号。
    D:else后面如果没有if,是不会出现比较表达式的。
    E:三种if语句其实都是一个语句,只要有一个执行,其他的就不再执行。

**如果运行语句只有一句,可以不加{};
如代码:
public static void main(String args[])
{
int x = 10;
if(x!=10)
System.out.println("x等于10");
if (x == 20)
System.out.println("x等于20");
System.out.println("over");
}
运行结果:over

**易错点,小心;的添加,上述代码,如果给if(x!=10)后面加;  ,会出现如下情况

    public static void main(String args[])
{
    int x = 10;
    if (x != 10);
    System.out.println("x等于10");
    if (x == 20)
        System.out.println("x等于20");
    System.out.println("over");
}
    运算结果:x等于10    over
    *为什么?
    此时的分号可以让此次if语句无效,则会直接输出,然后进入下次的if语句;

    switch语句

    **格式:
    switch(表达式) {
        case 值1:
            语句体1;
            break;
        case 值2:
            语句体2;
            break;
        ...
        default:
            语句体n+1;
            break;
    }

    **格式解释说明:
        switch:说明这是switch语句。
        表达式:可以是byte,short,int,char
            JDK5以后可以是枚举
            JDK7以后可以是字符串
        case:后面的值就是要和表达式进行比较的值
        break:表示程序到这里中断,跳出switch语句
        default:如果所有的情况都不匹配,就执行这里,相当于if语句中的else

                **小问题: switch语句的表达式可以是byte吗?可以是long吗?可以是String吗?
        可以,不可以,JDK7以后可以

**执行流程:
A:首先计算表达式的值
B:和每一个case进行匹配,如果有就执行对应的语句体,看到break就结束。
C:如果没有匹配,就执行default的语句体n+1。

            **注意事项:
    A:case后面只能是常量,不能是变量,而且,多个case后面的值不能出现相同的
    B:default可以省略吗?
        可以省略,但是不建议,因为它的作用是对不正确的情况给出提示。
        特殊情况:
            case就可以把值固定。
            A,B,C,D
    C:break可以省略吗?
        可以省略,但是结果可能不是我们想要的。
        会出现一个现象:case穿透。
        最终我们建议不要省略
    D:default一定要在最后吗?
        不是,可以在任意位置。但是建议在最后。
    E:switch语句的结束条件
        a:遇到break就结束了
        b:执行到末尾就结束了

            ****if语句和switch语句各自的场景
    A:if
        针对boolean类型的判断
        针对一个范围的判断
        针对几个常量的判断
    B:switch
        针对几个常量的判断

    **下面对循环语句做出解释:
    for,while,do...while

    **for循环语句
    A:格式
        for(初始化语句;判断条件语句;控制条件语句){
            循环体语句;
        }

     **执行流程:
            a:执行初始化语句
            b:执行判断条件语句
                如果这里是true,就继续
                如果这里是false,循环就结束
            c:执行循环体语句
            d:执行控制条件语句
            e:回到b
     **B:注意事项
        a:判断条件语句无论简单还是复杂,结果是boolean类型
        b:循环体语句如果是一条,可以省略大括号,但是不建议
        c:有分号就没有左大括号,有左大括号就没有分号

                    **while循环
    **A:基本格式
        while(判断条件语句) {
            循环体语句;
        }

     **扩展格式:
        初始化语句;
        while(判断条件语句){
            循环体语句;
            控制条件语句;
        }

        通过查看这个格式,我们就知道while循环可以和for循环等价转换。

            **for和while的区别
        **a:使用上的区别
            for语句的那个控制条件变量,在循环结束后不能在使用了。
            而while的可以继续使用。
        b:理解上的区别
            for适合于一个范围的判断
            while适合次数不明确的

                **do...while循环
   ** A:基本格式
        do {
            循环体语句;
        }while(判断条件语句);

        **扩展格式:
        初始化语句;
        do {
            循环体语句;
            控制条件语句;
        }while(判断条件语句);

        通过查看格式,我们就可以看出其实三种循环的格式可以是统一的。
   ** B:三种循环的区别
        a:do...while循环至少执行一次循环体
        b:for和while必须先判断条件是否是true,然后后才能决定是否执行循环体

         **循环使用的注意事项(死循环)
    A:一定要注意修改控制条件,否则容易出现死循环。
    B:最简单的死循环格式
        a:while(true){...}

        b:for(;;){}

转载于:https://blog.51cto.com/13678296/2312504

相关文章:

  • 【转】在Win7的IIS上搭建FTP服务及用户授权
  • layui-学习02-全局样式
  • Mac OS 系统占用储存空间太大怎么办?
  • 生产管理软件改进生产流程
  • 双十一移动端页面总结
  • PYTHON——多进程:概念
  • Android开发 - 掌握ConstraintLayout(四)创建基本约束
  • Python爬取新浪微博用户信息及微博内容
  • IIS7应用程序池集成和经典的区别
  • Es学习第二课, ES安装和客户端使用
  • EOS源码解析 eosio账号默认合约
  • 项目总结11:Centos部署JDK+Tomcat+MySQL文档(阿里云-网易云-华为云)
  • Oracle Procedure模板
  • 扫呗扫码点餐,如何在扫呗后台给这个商户配一下支付授权地址
  • 外网访问内网Resin
  • [译] React v16.8: 含有Hooks的版本
  • [译]前端离线指南(上)
  • “寒冬”下的金三银四跳槽季来了,帮你客观分析一下局面
  • 【MySQL经典案例分析】 Waiting for table metadata lock
  • 【技术性】Search知识
  • extract-text-webpack-plugin用法
  • git 常用命令
  • hadoop集群管理系统搭建规划说明
  • iOS筛选菜单、分段选择器、导航栏、悬浮窗、转场动画、启动视频等源码
  • jquery cookie
  • Laravel 中的一个后期静态绑定
  • Median of Two Sorted Arrays
  • python3 使用 asyncio 代替线程
  • SpiderData 2019年2月23日 DApp数据排行榜
  • 复杂数据处理
  • 基于Android乐音识别(2)
  • 力扣(LeetCode)56
  • 那些年我们用过的显示性能指标
  • 前端攻城师
  • 悄悄地说一个bug
  • 删除表内多余的重复数据
  • 文本多行溢出显示...之最后一行不到行尾的解决
  • 小程序测试方案初探
  • 好程序员web前端教程分享CSS不同元素margin的计算 ...
  • 进程与线程(三)——进程/线程间通信
  • 如何通过报表单元格右键控制报表跳转到不同链接地址 ...
  • !!【OpenCV学习】计算两幅图像的重叠区域
  • #pragma once与条件编译
  • (2009.11版)《网络管理员考试 考前冲刺预测卷及考点解析》复习重点
  • (3)选择元素——(14)接触DOM元素(Accessing DOM elements)
  • (4) PIVOT 和 UPIVOT 的使用
  • (8)Linux使用C语言读取proc/stat等cpu使用数据
  • (aiohttp-asyncio-FFmpeg-Docker-SRS)实现异步摄像头转码服务器
  • (二)springcloud实战之config配置中心
  • (附源码)ssm基于web技术的医务志愿者管理系统 毕业设计 100910
  • (附源码)小程序儿童艺术培训机构教育管理小程序 毕业设计 201740
  • (五)MySQL的备份及恢复
  • (原)Matlab的svmtrain和svmclassify
  • (正则)提取页面里的img标签
  • (转)利用ant在Mac 下自动化打包签名Android程序