2019独角兽企业重金招聘Python工程师标准>>>
//不要在boolean类型与任何数值类型之间进行强制类型转换,这样可以防止发生错误。只有极少数的情况才需要将布尔类型转换为数值类型,
//这时可以使用条件表达式 b ? 1 : 0//enum Size = {SMALL, MEDUIUM, LARGE}
// Size s = Size.MEDUIUM;//一定不能使用 == 运算符检测连个字符串是否相等, 这个运算符只能确定两个字符串是否放置在同一个位置上。
//当然,如果字符串放置在同一个位置上,它们必然是相等的。
//但是, 完全有可能将内容相同的多个字符串的拷贝放置在不同的位置上。String greeting = "hello";
if(greeting == "hello")
{System.out.println("true");
}if(greeting.substring(0, 3) != "hel")
{System.out.println("false");
}// 如果虚拟机始终将相同的字符串共享,就可以使用 == 运算符检测是否相等。
// 但实际上只有字符串常量是共享的,而+ 或 substring等操作产生的结果并不是共享的。
// 因此, 千万不要使用 ==运算符测试字符串的相等性,以免在程序中出现糟糕的bug.
// 从表面上看,这种bug很想随机产生的间接性错误。//可以使用equals方法检测两个字符串是否相等,对于表达式:
// s.equals(t)
输入输出:
package test;import java.util.*;/*** This program demonstrates console input.* @version * @author lvhuizhen* */
public class test {public static void main(String[] args){Scanner in = new Scanner(System.in);//get first inputSystem.out.print("what is your name ?");String name = in.nextLine();//get second inputSystem.out.print("How old are you?");int age = in.nextInt();//display output on consoleSystem.out.println("Hello, " + name + ".Next year, you'll be " + (age+1));}
}
java.util.Scanner 5.0
Scanner (InputStream in)
用给定的输入流创建一个Scanner对象。
String nextLine()
读取输入的下一行内容。
String next()
读取输入的下一个单词(以空格作为分隔符)
int nextInt()
double nextDouble()
读取并转换下一个表示整数或浮点数的字符序列
boolean hasNext()
检测输入中是否还有下一个其他单词。
boolean hasNextInt()
boolean hasNextDouble()
检测是否还有表示整数或浮点数的下一个字符序列
控制流程:
Java 的控制流程结构与C和C++的控制流程结构一样,只有很少的例外情况。没有goto语句,但break语句可以带标签,可以利用它实现从内层循环跳出的目的(这种情况C语言采用goto语句实现)。另外,还有一种变形的for循环,在C或者C++中没有这类循环。它有点类似于javascript中的for循环。
在C++中,可以在嵌套的块中重定义一个变量。在内层定义的变量会覆盖在外层定义的变量。这样,有可能会导致程序设计错误,因此在Java中不允许这样做。
数组:
创建一个数字数组时,所有元素都初始化为0.
boolean数据的元素会初始化为false.
对象数组的元素则初始化为一个特殊值NULL,这表示这些元素(还)未存放任何对象。
String[] name = new String[10];
会创建一个包含10个字符串的数组,所有字符串都为NULL。如果希望这个数组包含空串,可以为元素指定空串。
for(int i = 0; i < 10; i++) names[i] "";
Java数组与C++数组在堆栈上有很大的不同,但基本上与分配在堆(heap)上的数组指针一样。也就是说,
int [] a = new int[100]; //Java
不同于
int a[100]; //c++
而等同于
int * a = new int[100]; //c++
java中的[]运算符被预定义为检查数组边界,而且没有指针运算,即不能通过a加上1得到数组的下一个元素。