全面认识java控制流程
块(即复合语句)是指由若干条Java语句组成的语句,并用一对大括号括起来。
块确定了变量的作用域。
一个块可以嵌套在另一个块中。下面就是嵌套在main方法块中的一个块。
public static void main(String[] args){
int n;
...
{
int k;
...
}//k is only defind up to here
}
但是,不能在嵌套的两个块中声明同名的变量。
public static void main(String[] args){
int n;
...
{
int k;
int n; //ERROR---can't redefine n in inner block
...
}//k is only defind up to here
}
在Java中,条件语句的形式为if (condition) statement,这里的条件必须用小括号括起来。
if(yourSales >= target)
{
performance = "Satisfactory";
bonus = 100;
}
//当 yourSales大于或等于target 时,将执行大括号中的所有语句
while,do-while和for用来控制循环,它们也叫作迭代语句(iteration statement)。while(condition) statementwhile循环语句在最前面检测循环条件。因此,循可能一次都不执行。如果希望循环体至少执行一次,需要使do-while循环将检测放在最后。do statement while(condition);for(initialization;boolean-expression;step) statement
for(int i= 1;i <= 10;i++)
{
...
}
//i no longer defined here
int i;
for(i= 1;i <= 10;i++)
{
...
}
//i is still defined here
for(int i= 1;i <= 10;i++)
{
...
}
for(int i= 11;i <= 20;i++)
//OK to define another variable named i
{
...
}
for(i= 1;i > 10;i--)
{
...
}
int i = 10;
while(i > 0){
i--;
}
更加简洁的for语法,可以用于数组和容器,有时候叫作"増强的for" ( enhanced for )。大部分文档中直接将其称为foreach语法,但Java 8里又增加了一个我们经常使用的forEach()方法。这样的术语使用起来容易混淆,在《On Java》中叫做for-in语法import java.util.*;
public class ForInFloat{
public static void main(String[] args){
float[] f = new float[10];
for(int i = 0;i < 10;i++) //旧式的for循环
f[i] = i;
for(float x : f) //for-in语法
System.out.println(x);
}
}
for(float x : f)这条语句定义了一个float类型的变x,然后会将数组f里的每一个元素按顺序赋给x任何返回了数组的方法都可以使用for-in
public class ForInString{
public static void main(String[] args){
for(char c : "An African Swallow".toCharArray())
System.out.println(c + " ");
for(int i = 0;i < 10;i++),对于这些语句,for-in语法不起作用,因为你需要先创建一个int数组。break会直接退出循环,不再执行循环里的剩余语句。continue则会停止执行当前的迭代,然后退回循环开始位置执行下一次迭代。while(y <= 100){
b += p;
double i = b * 2.5;
b += i;
if(b >= 10) break; // <--break语句
years++;
}
用于跳出多重嵌套的循环语句。标签必须放在希望跳出的最外层循环之前,并且必须紧跟一个冒号。Scanner in = new Scanner(System.in);
int n;
read_data: //<--标签,带冒号
while(...){
...
for(...){
...
if(...)
break read_data;
//执行带标签的break会跳转到带标签的语句块末尾
}
}
//break之后,跳到此处
Scanner in = new Scanner(System.in);
while(...){
...
int n = in.nextInt();
if(n < 0) continue;
//如果n<0,则continue语句越过了当前
//循环体的剩余部分,立刻跳到循环首部。
...
}
Scanner in = new Scanner(System.in);
for(count = 1;count <= 100;count++){
...
int n = in.nextInt();
if(n < 0) continue;
//如果n<0,则continue 语句将跳到count++语句
...
}
标签:标签是以冒号结尾的标识符,形如 label:
不要在标签和迭代之间播入任何语句label:
outer-iteration{
inner-iteration{
//... //[1]
break;
//... //[2]
continue;
//... //[3]
continue label;
//... //[4]
break label;
}
}
- [1]这里的break中断内部迭代,回到外部迭代
- [2] 这里的continue中断当前执行,回到内部迭代的开始位置
- [3] 这里的continue label会同时中断内部迭代以及外部迭代,直接跳到label处,然后它实际上会
重新进入外部迭代开始继续执行。- [4] 这里的break label也会中断所有迭代,跳回到labell处,不过它
并不会重新进入外部迭代。它实际是完全跳出了两个迭代。
处理多个选项时,使用if-else结构显得有些笨拙,Java 有一个与C/C++完全一样的switch 语句switch(integral-selector){
case integral-value1 : statement; break;
case integral-value2 : statement; break;
case integral-value3 : statement; break;
case integral-value4 : statement; break;
case integral-value5 : statement; break;
//...
default:statement;
}
整数选择器(integral-selector)是一个能生成整数值的表达式.switch将这个表达式的结果与每个整数值(integral-value )相比较:
break结尾,它会让执行流程跳到switch主体的末尾
break是可选的。如果省略后面的case语句也会被执行,直到遇到一个breakdefault语句里没有break,这是因为default语句执行完的地方,本来就是bieak跳转的目的地在Java 7之前,switch的选择器执行结果必须是整数值,比如int或char;Java 7的switch选择器不但可以使用整数值,还添加了使用字符串的能力
当我在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
无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD
这篇文章是继上一篇文章“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)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候