java.util.Scanner是Java5的新特征,我们可以通过Scannner类来获取用户的输入。
Scanner s = new Scanner(System.in);
通过Scanner类的next()与nextLine()方法获取输入的字符串,在读取前一般需要使用hasNext()与hasNextLine()判断是否还有输入的数据。
next()
一定要读取到有效字符后才可以结束输入
对输入有效字符之前遇到的空白,next()方法会自动将其去掉
只有输入有效字符后才能将其后面输入的空白作为分隔符或者结束符
next()不能得到带有空格的字符串
nextLine()
nextLine()是以Enter(回车)作为结束符,也就是说nextLine()方法返回的是输入回车之前的所有字符
可以获取空白
例子1
package li.bolog.scanner;
import java.util.Scanner;
public class Demo01 {
public static void main(String[] args) {
//创建一个扫描器对象,用于接收键盘数据
Scanner scanner = new Scanner(System.in);
System.out.println("使用next方式接收:");
//判断用户有没有输入字符串
if(scanner.hasNext()){
String str = scanner.next();//程序会等待用户输入完毕
System.out.println("输入的内容为:"+str);
}
//凡是属于IO流的类如果不关闭会一直占用资源,要养成好习惯用完就关掉。
scanner.close();
}
}

例子2
package li.bolog.scanner;
import java.sql.SQLOutput;
import java.util.Scanner;
public class Demo02 {
public static void main(String[] args) {
Scanner scanner =new Scanner(System.in);
System.out.println("使用nextLine方式接收:");
//判断是否还有输入
if (scanner.hasNextLine()){
//使用nextLine方式接收
String str=scanner.nextLine();
System.out.println("输入的内容为:"+str);
}
scanner.close();
}
}

例子3
package li.bolog.scanner;
import java.util.Scanner;
public class Demo03 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.println("请输入数据:");
String str = scanner.nextLine();
System.out.println("输出的内容为:"+str);
scanner.close();
}
}

例子4
package li.bolog.scanner;
import java.util.Scanner;
public class Demo05 {
public static void main(String[] args) {
//我们可以输入多个数字,并求其总和与平均数,每输入一个数字用回车键确认。通过输入非数字来结束输入并输出执行结果。
Scanner scanner = new Scanner(System.in);
//和
double sum = 0;
//计算输入了多少个数字
int m = 0;
System.out.println("请输入数据:");
//通过循环判断是否还有数字输入,并在里面对每一次进行求和和统计
while(scanner.hasNextDouble()){
double x = scanner.nextDouble();
m=m+1;
sum=sum+x;
System.out.println("你输入了第"+m+"个数据,当前结果sum="+sum);
}
System.out.println(m+"个数的和为:"+sum);
System.out.println(m+"个数的平均数为:"+(sum/m));
scanner.close();
}
}

Java的基本结构就是顺序结构,除非特别指明。否则就按照顺序一句一句执行
顺序结构是最简单的算法结构
语句与语句之间,框与框之间是按照从上到下的顺序进行的,它是由若干个一次执行的处理步骤组成的,它是任何一个算法都离不开的一种基本的算法结构。
我们很多时候需要去判断一个东西是否可行再去执行,这样一个过程在程序中用if语句来表示。
语法:
if(布尔表达式){
//这里是如果布尔表达式为true,则将执行的语句
}
例子
package li.bolog.struct;
import java.util.Scanner;
public class IfDemo01 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.println("请输入内容:");
String s= scanner.nextLine();
//equals:判断字符串是否相等
if(s.equals("Hello")){
System.out.println(s);
}
System.out.println("End");
scanner.close();
}
}


语法:
if(布尔表达式){
//这里是如果布尔表达式为true则将执行的语句
}else{
//这里是布尔表达式为false则将执行的语句
}
例子
package li.bolog.struct;import java.util.Scanner;
public class IfDemo02 {
public static void main(String[] args) {
//考试成绩大于60分则及格,否则不及格
Scanner scanner = new Scanner(System.in);System.out.println("请输入成绩:"); int score = scanner.nextInt(); if(score>=60){ System.out.println("成绩及格!"); }else{ System.out.println("成绩不及格!"); } scanner.close(); }
}

语法:
if(布尔表达式1){
//这里是如果布尔表达式1为true则将执行的语句
}else if(布尔表达式2){
//这里是如果布尔表达式2为true则将执行的语句
}else if(布尔表达式3){
//这里是如果布尔表达式3为true则将执行的语句
}...else{
//如果以上布尔表达都不为true则执行这里的代码
}
if语句至多有一个else语句,else语句在所有的else if语句之后
if语句可以有若干个else if 语句,它们必须在else语句之前
一旦其中一个else if语句检测为true,其他的else if以及else语句都将跳过
例子
package li.bolog.struct;import java.util.Scanner;
public class IfDemo03 {
public static void main(String[] args) {
//考试成绩大于60分则及格,否则不及格
Scanner scanner = new Scanner(System.in);System.out.println("请输入成绩:"); int score = scanner.nextInt(); if(score==100){ System.out.println("成绩满分!"); }else if(score<100&&score >=90){ System.out.println("成绩:A"); }else if(score<90&&score >=80){ System.out.println("成绩:B"); } else if(score<80&&score >=70){ System.out.println("成绩:C"); } else if(score<70&&score >=60){ System.out.println("成绩:D"); }else if(score<60&&score>=0){ System.out.println("成绩不合格!"); }else{ System.out.println("成绩非法!"); } scanner.close(); }
}

使用嵌套的if…else语句是合法的。也就是说你可以在另一个if或者else if语句中使用if或者else if语句。你可以像if语句一样嵌套else if…else
语法:
if(布尔表达式1){
//如果布尔表达式1为true则执行的语句
if(布尔表达式2){
//这里是如果布尔表达式2为true则将执行的语句
}
}
多选择结构还有一个实现方式就是switch case语句
switch case语句判断一个变量与一系列值中的某个值是否相等,每一个值称为一个分支
switch语句中的变量类型可以是:
byte、short、int或者char
从Java SE 7开始 switch支持字符串类型,同时case标签必须为字符串常量或字面量
语法:
switch(expression){
case value:
//语句
break;//可选
case value:
//语句
break;//可选
//你可以有任意数量的case语句
default://可选
//语句
}
例子:case穿透现象
在switch语句中,如果case的后面不写break,将出现穿透现象,也就是不会在判断下一个case的值,直接向后运
行,直到遇到break,或者整体switch结束。
package li.bolog.struct;public class SwitchDemo01 {
public static void main(String[] args) {
//
char grade='A';switch(grade){ case 'A': System.out.println("优秀"); case 'B': System.out.println("良好"); case 'C': System.out.println("及格");break; default: System.out.println("未知等级"); } }
}

例子:switch支持字符串类型
package li.bolog.struct;public class SwitchDemo02 {
public static void main(String[] args) {
String name = "中国";
//JDK7的新特性标,表达式结果可以是字符串!!
//字符串的本质还是数字//反编译 java--class(字节码文件)----反编译(这里用IDEA实现) switch(name){ case "英国": System.out.println("英国");break; case "美国": System.out.println("美国");break; case "中国": System.out.println("中国");break; default: System.out.println("弄啥嘞?"); } }
}
字符串的本质还是数字
这里使用IDEA反编译该java文件对应的class文件,得到如下:
可以看到, switch(name)变成了switch(name.hashCode()),case后面对应的字符串变成了数字。每一个中文都会有对应的哈希值,根据哈希值判断中文是否相同。
// // Source code recreated from a .class file by IntelliJ IDEA // (powered by FernFlower decompiler) //package li.bolog.struct;
public class SwitchDemo02 {
public SwitchDemo02() {
}public static void main(String[] args) { String name = "中国"; byte var3 = -1; switch(name.hashCode()) { case 642672: if (name.equals("中国")) { var3 = 2; } break; case 1034543: if (name.equals("美国")) { var3 = 1; } break; case 1061420: if (name.equals("英国")) { var3 = 0; } } switch(var3) { case 0: System.out.println("英国"); break; case 1: System.out.println("美国"); break; case 2: System.out.println("中国"); break; default: System.out.println("弄啥嘞?"); } }
}
while循环
do...while循环
for循环
在java5中引入了一种主要用于数组的增强型for循环
while是最基本的循环,它的结构为:
while(布尔表达式){
//循环内容
}
只要布尔表达式为true,循环就会一直执行下去
如果想要循环停下来,就需要一个表达式失效的方式来结束循环
循环条件一直true就会造成无限循环[死循环]
例子:输出1-100
package li.bolog.struct;public class WhileDemo01 {
public static void main(String[] args) {
//输出1到100
int i = 0;while(i<100){ i++; System.out.print(i); } }
}

例子:计算1+2+...+100
package li.bolog.struct;
public class WhileDemo02 {
public static void main(String[] args) {
//计算1+2+...+100
int i=0;
int sum=0;
while(i<=100){
sum=sum+i;
i++;
}
System.out.println(sum);
}
}

对于while语句而言,若果不满足条件,则不能进入循环。但有时候我们需要即使不满足条件,也至少执行一次。
do...while循环和while循环相似,不同的是,do...while循环至少会执行一次
语法:
do{
//代码语句
}
while(布尔表达式);
while和do...while的区别:
while先判断后执行,do-while是先执行后判断
do-while总是保证循环体至少会被执行一次!这是他们的主要区别
例子:计算1+2+...+100
package li.bolog.struct;
public class DoWhlieDemo01 {
public static void main(String[] args) {
int i=0;
int sum=0;
do{
sum=sum+i;
i++;
}while(i<=100);
System.out.println(sum);
}
}

例子:while和do-while
package li.bolog.struct;
public class DoWhileDemo02 {
public static void main(String[] args) {
int a=0;
while (a<0){
System.out.println(a);
a++;
}
System.out.println("===========");
do{
System.out.println(a);
a++;
}while(a<0);
}
}

for循环语句是支持迭代的一种通用结构,是最有效,最灵活的循环结构
for循环执行的次数是在执行前就确定的。
语法:
for(初始化;布尔表达式;更新){
//代码语句
}
例子:while和for循环对比
package li.bolog.struct;public class ForDemo01 {
public static void main(String[] args) {
int a = 1;//初始化条件
while(a<=100){//条件判断
System.out.print(a+" ");//循环体
a+=8;//迭代
}
System.out.println("while循环结束!");//初始化 //条件判断 //迭代 for(int i=1;i<=100;i=i+8){ System.out.print(i+" "); } System.out.println("for循环结束!"); }
}

关于for循环有以下几点说明:
最先执行的初始化步骤可以声明一种变量,也可初始化一个或者多个循环控制变量,也可以是空语句
然后执行检测布尔表达式的值,如果为true,循环体执行;如果为false,循环终止,开始执行循环体后面的语句
执行一次循环后,更新循环控制变量(迭代因子控制循环变量的增减)
再次检测布尔表达式。循环执行上面的过程
练习1:分别计算0到100之间奇数和、偶数和
package li.bolog.struct;public class ForDemo02 {
public static void main(String[] args) {
//分别计算0到100之间奇数和、偶数和
int oddSum=0;
int evenSum=0;for (int i=0;i<=100;i++){ if(i%2!=0){ oddSum=oddSum+i; } else { evenSum=evenSum+i; } } System.out.println("奇数的和:"+oddSum); System.out.println("偶数的和:"+evenSum); }
}

练习2:用while或for循环输出1-1000之间能被5整除的数,并且每行输出3个
package li.bolog.struct;public class ForDemo03 {
public static void main(String[] args) {
//用while或for循环输出1-1000之间能被5整除的数,并且每行输出3个for (int i=1;i<=1000;i++){ if(i%5==0){ System.out.print(i+"\t"); } if(i%(5*3)==0){//每行输出的第三个值都是15的倍数,因此除以15 System.out.println();//或者System.out.println("\n"); } } }
}


练习3:打印九九乘法表
package li.bolog.struct;
public class ForDemo04 {
public static void main(String[] args) {
//我们先打印第一列
//我们先把固定的j用一个循环包起来
//去掉重复项,j<=i
//调整样式
for(int i=1;i<=9;i++){
for (int j=1;j<=i;j++){
System.out.print(i+""+j+"="+(ij)+"\t");
}
System.out.println();
}
}
}

增强for循环:
Java5引入了一种主要用于数组或者集合的增强型for循环
Java增强for循环语法格式如下:
for(声明语句:表达式){
//代码句子
}
声明语句:声明新的局部变量,该变量的类型必须和数组元素的类型匹配。其作用域限定在循环语句块,其值与此时数组元素的值相等
表达式:表达式是要访问的数组名,或者是返回值为数组的方法
package li.bolog.struct;public class ForDemo05 {
public static void main(String[] args) {
int[] number={10,20,30,40};//定义了一个数组for(int i=0;i<4;i++){ System.out.println(number[i]); } System.out.println("========="); //遍历数组元素 for(int x:number){ System.out.println(x); } }
}

break,在任何循环语句的主体部分均可用break控制循环的的流程。break用于强行退出循环,不执行循环中剩余的语句。(break语句也在switch语句中使用)
continue语句用在循环语句体中,用于终止某次循环过程,即跳过循环体中尚未执行的语句,接着进行下一次是否执行循环体的判定。
例子:break
package li.bolog.struct;
public class BreakDemo {
public static void main(String[] args) {
int i=0;
while(i<100){
i++;
System.out.println(i);
if(i==30)break;
}
}
}
例子:continue
package li.bolog.struct;
public class ContinueDemo {
public static void main(String[] args) {
int i=0;
while(i<100){
i++;
if(i%10==0){
System.out.println();
continue;
}
System.out.print(i+"\t");
}
}
}
package li.bolog.struct;
public class TestDemo {
public static void main(String[] args) {
//打印三角形 5行
for (int i = 1; i <= 5; i++) {//idea快捷键 5.for
for (int j = 5; j >= i; j--) {//先打印空格倒三角
System.out.print(" ");
}
for (int j = 1; j <=i; j++) {
System.out.print("*");//和上面相反,打印向左正三角
}
for (int j = 1; j <i; j++) {
System.out.print("*");//和上面相同,打印向右正三角,不是j<=i的原因是因为第一行已经有一个*了
}
System.out.println();
}
}
}
**debug:**
1.在代码左侧左键打上断点
2.点击导航栏的虫子图标
3.可以在底部状态栏中看到当前程序执行的过程(点击向下单箭头可以按步执行)
当我在Rails控制台中按向上或向左箭头时,出现此错误:irb(main):001:0>/Users/me/.rvm/gems/ruby-2.0.0-p247/gems/rb-readline-0.4.2/lib/rbreadline.rb:4269:in`blockin_rl_dispatch_subseq':invalidbytesequenceinUTF-8(ArgumentError)我使用rvm来管理我的ruby安装。我正在使用=>ruby-2.0.0-p247[x86_64]我使用bundle来管理我的gem,并且我有rb-readline(0.4.2)(人们推荐的最少
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
我正在使用Ruby2.1.1和Rails4.1.0.rc1。当执行railsc时,它被锁定了。使用Ctrl-C停止,我得到以下错误日志:~/.rvm/gems/ruby-2.1.1/gems/spring-1.1.2/lib/spring/client/run.rb:47:in`gets':Interruptfrom~/.rvm/gems/ruby-2.1.1/gems/spring-1.1.2/lib/spring/client/run.rb:47:in`verify_server_version'from~/.rvm/gems/ruby-2.1.1/gems/spring-1.1.
我将我的Rails应用程序部署到OpenShift,它运行良好,但我无法在生产服务器上运行“Rails控制台”。它给了我这个错误。我该如何解决这个问题?我尝试更新rubygems,但它也给出了权限被拒绝的错误,我也无法做到。railsc错误:Warning:You'reusingRubygems1.8.24withSpring.UpgradetoatleastRubygems2.1.0andrun`gempristine--all`forbetterstartupperformance./opt/rh/ruby193/root/usr/share/rubygems/rubygems
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht
这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/
HashMap中为什么引入红黑树,而不是AVL树呢1.概述开始学习这个知识点之前我们需要知道,在JDK1.8以及之前,针对HashMap有什么不同。JDK1.7的时候,HashMap的底层实现是数组+链表JDK1.8的时候,HashMap的底层实现是数组+链表+红黑树我们要思考一个问题,为什么要从链表转为红黑树呢。首先先让我们了解下链表有什么不好???2.链表上述的截图其实就是链表的结构,我们来看下链表的增删改查的时间复杂度增:因为链表不是线性结构,所以每次添加的时候,只需要移动一个节点,所以可以理解为复杂度是N(1)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候
说在前面这部分我本来是合为一篇来写的,因为目的是一样的,都是通过独立按键来控制LED闪灭本质上是起到开关的作用,即调用函数和中断函数。但是写一篇太累了,我还是决定分为两篇写,这篇是调用函数篇。在本篇中你主要看到这些东西!!!1.调用函数的方法(主要讲语法和格式)2.独立按键如何控制LED亮灭3.程序中的一些细节(软件消抖等)1.调用函数的方法思路还是比较清晰地,就是通过按下按键来控制LED闪灭,即每按下一次,LED取反一次。重要的是,把按键与LED联系在一起。我打算用K1来作为开关,看了一下开发板原理图,K1连接的是单片机的P31口,当按下K1时,P31是与GND相连的,也就是说,当我按下去时