这段时间读了《Programming in Scala》,对Scala的语法有种熟悉的感觉:
js中经常会写一些很短的工具函数,就是这样子滴!现在流行的一个编码理念就是每个函数的功能尽量单一,代码的行数尽量少-函数化编程,twitter中的scala消息转发系统中有大量的小函数。函数化编程思想在Scala中另种体现,
并在编译的时候生成类while循环的字节码。强悍的match表达式-比switch更方便、强大的模式匹配表达式,也是actor模型的实现基础,思想类似于Spring中的ThrowsAdvice中的方法模式匹配。
函数化编程在传参的时候,参数是不可变的对象,这样在多线程的环境下,就不用考虑对象的同步和竞争,但是为了兼容java开发人员的思维,并且为不可变对象提供相应可变的类实现。不可变对象在编码中可能会出现大量的对象创建和回收事件,在老版本的JVM中对象的回收肯定是一件很悲催的事情,在JDK5中新的改进的回收算法为JVM平台上的动态语言提供舞台。
和C++中的运算符一样的重载方式,这在Java语言中已经被摒弃的特性又回来了。运算符重载又导致了不同类型之间的对象的操作顺序不同导致的编译错误。Scala的解决办法是增加“ 隐式转换”转换的特性,但是太多“隐式转换”会导致源码维护阅读的麻烦,C++的解决办法是为运算符不同顺序的写法都定义好重载的格式,易于阅读,但增加了代码量。
集合对象的初始化方式、数组对象的初始化方式、数据的赋值和类型推断。
没有Interface。
(未完待续)
感觉Scala是披着java外衣的新语言,Scala并没有和java语法100%兼容,在scala中添加了很多的特性,还是有学习曲线的-当然比closurej容易多了。一次性添加很多特性,比挤牙膏似一点一点添加新特性更好,难度更大。当年有篇恶搞文章是采访C++之父,问他为什么发明C++,他说C太容易了,要为程序员创造一个新的、更复杂的语言来增加收入。莫非Scala也是这样想的?!
转贴:Java 7已经完成的7大新功能
http://www.blogjava.net/ywj-316/archive/2011/03/18/346539.html
1 对集合类的语言支持;
2 自动资源管理;
3 改进的通用实例创建类型推断;
4 数字字面量下划线支持;
5 switch中使用string;
6 二进制字面量;
7 简化可变参数方法调用。
下面我们来仔细看一下这7大新功能:
1 对集合类的语言支持
Java将包含对创建集合类的第一类语言支持。这意味着集合类的创建可以像Ruby和Perl那样了。
原本需要这样:
List<String> list = new ArrayList<String>();
list.add("item");
String item = list.get(0);
Set<String> set = new HashSet<String>();
set.add("item");
Map<String, Integer> map = new HashMap<String, Integer>();
map.put("key", 1);
int value = map.get("key");
现在你可以这样:
List<String> list = ["item"];
String item = list[0];
Set<String> set = {"item"};
Map<String, Integer> map = {"key" : 1};
int value = map["key"];
这些集合是不可变的。
2 自动资源管理
Java中某些资源是需要手动关闭的,如InputStream,Writes,Sockets,Sql classes等。这个新的语言特性允许try语句本身申请更多的资源,
这些资源作用于try代码块,并自动关闭。
这个:
BufferedReader br = new BufferedReader(new FileReader(path));
try {
return br.readLine();
} finally {
br.close();
}
变成了这个:
try (BufferedReader br = new BufferedReader(new FileReader(path)) {
return br.readLine();
}
你可以定义关闭多个资源:
try (
InputStream in = new FileInputStream(src);
OutputStream out = new FileOutputStream(dest))
{
// code
}
为了支持这个行为,所有可关闭的类将被修改为可以实现一个Closable(可关闭的)接口。
3 增强的对通用实例创建(diamond)的类型推断
类型推断是一个特殊的烦恼,下面的代码:
Map<String, List<String>> anagrams = new HashMap<String, List<String>>();
通过类型推断后变成:
Map<String, List<String>> anagrams = new HashMap<>();
这个<>被叫做diamond(钻石)运算符,这个运算符从引用的声明中推断类型。
4 数字字面量下划线支持
很长的数字可读性不好,在Java 7中可以使用下划线分隔长int以及long了,如:
int one_million = 1_000_000;
运算时先去除下划线,如:1_1 * 10 = 110,120 – 1_0 = 110
5 switch中使用string
以前你在switch中只能使用number或enum。现在你可以使用string了:
String s = ...
switch(s) {
case "quux":
processQuux(s);
// fall-through
case "foo":
case "bar":
processFooOrBar(s);
break;
case "baz":
processBaz(s);
// fall-through
default:
processDefault(s);
break;
}
6 二进制字面量
由于继承C语言,Java代码在传统上迫使程序员只能使用十进制,八进制或十六进制来表示数(numbers)。
由于很少的域是以bit导向的,这种限制可能导致错误。你现在可以使用0b前缀创建二进制字面量:
int binary = 0b1001_1001;
现在,你可以使用二进制字面量这种表示方式,并且使用非常简短的代码,可将二进制字符转换为数据类型,如在byte或short。
byte aByte = (byte)0b001;
short aShort = (short)0b010;
7 简化的可变参数调用
当程序员试图使用一个不可具体化的可变参数并调用一个*varargs* (可变)方法时,编辑器会生成一个“非安全操作”的警告。
JDK 7将警告从call转移到了方法声明(methord declaration)的过程中。这样API设计者就可以使用vararg,因为警告的数量大大减少了。