Java 8 introduced several new features including lambda expressions, default methods in interfaces, streams API and others. Lambda expressions allow implementing functional interfaces using anonymous functions. Interfaces can now define default and static methods. The streams API allows performing bulk operations on collections in a declarative way. Some performance improvements in Java 8 include faster common data structures like HashMap, garbage collector improvements and enhanced fork/join framework.