Effective Java Quotes
7,906 ratings, 4.51 average rating, 413 reviews
Open Preview
Effective Java Quotes
Showing 1-28 of 28
“Learning the art of programming, like most other disciplines, consists of first learning the rules and then learning when to break them.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“One advantage of static factory methods is that, unlike constructors, they have names.”
― Effective Java
― Effective Java
“Collection or an appropriate subtype is generally the best return type for a public, sequence- returning method.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“Writing concurrent programs in Java keeps getting easier, but writing concurrent programs that are correct and fast is as difficult as it ever was.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“A forEach operation that does anything more than present the result of the computation performed by a stream is a “bad smell in code,” as is a lambda that mutates state.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“and then tried to use it outside the classroom, you know that there are three things you must master: how the language is structured (grammar), how to name things you want to talk about (vocabulary), and the customary and effective ways”
― Effective Java
― Effective Java
“In other words, if you accept the default serialized form, the class’s private and package-private instance fields become part of its exported API, and the practice of minimizing access to fields loses its effectiveness as a tool for information hiding.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“In summary, serialization is dangerous and should be avoided. If you are designing a system from scratch, use a cross-platform structured-data representation such as JSON or protobuf instead. Do not deserialize untrusted data. If you must do so, use object deserialization filtering, but be aware that it is not guaranteed to thwart all attacks. Avoid writing serializable classes. If you must do so, exercise great caution.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“A fundamental problem with serialization is that its attack surface is too big to protect, and constantly growing: Object graphs are deserialized by invoking the readObject method on an ObjectInputStream. This method is essentially a magic constructor that can be made to instantiate objects of almost any type on the class path, so long as the type implements the Serializable interface. In the process of deserializing a byte stream, this method can execute code from any of these types, so the code for all of these types is part of the attack surface.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“Given the difficulty of using wait and notify correctly, you should use the higher-level concurrency utilities instead.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“When used to best advantage, exceptions can improve a program’s readability, reliability, and maintainability. When used improperly, they can have the opposite effect.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“In summary, never return null in place of an empty array or collection. It makes your API more difficult to use and more prone to error, and it has no performance advantages.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“This leaves a big question unanswered. Is it ever appropriate to store an optional in an instance field? Often it’s a “bad smell”: it suggests that perhaps you should have a subclass containing the optional fields. But sometimes it may be justified.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“To summarize, just because you can overload methods doesn’t mean you should.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“The behavior of this program is counterintuitive because selection among overloaded methods is static, while selection among overridden methods is dynamic.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“streams do not make iteration obsolete”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“arrays are covariant. This scary-sounding word means simply that if Sub is a subtype of Super, then the array type Sub[] is a subtype of the array type Super[]. Generics, by contrast, are invariant: for any two distinct types Type1 and Type2, List is neither a subtype nor a supertype of List. You might think this means that generics are deficient, but arguably it is arrays that are deficient.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“You can put any element into a collection with a raw type, easily corrupting the collection’s type invariant (as demonstrated by the unsafeAdd method on page 119); you can’t put any ele- ment (other than null) into a Collection<?>.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“Implementing a constant interface causes this implementation detail to leak into the class’s exported API. It is of no consequence to the users of a class that the class implements a constant interface. In fact, it may even confuse them. Worse, it represents a commitment: if in a future release the class is modified so that it no longer needs to use the constants, it still must implement the interface to ensure binary compatibility. If a nonfinal class implements a constant interface, all of its subclasses will have their namespaces polluted by the constants in the interface.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“If you export a nontrivial interface, you should strongly consider providing a skeletal implementation to go with it. To the extent possible, you should provide the skeletal implementation via default methods on the interface so that all implementors of the interface can make use of it.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“It is too early to say whether modules will achieve widespread use outside of the JDK itself. In the meantime, it seems best to avoid them unless you have a compelling need.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“Given all the problems associated with Cloneable, new interfaces should not extend it, and new extendable classes should not implement it.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“There is no way to extend an instantiable class and add a value component while preserving the equals contract, unless you’re willing to forgo the benefits of object-oriented abstraction.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“In fact, two-thirds of the uses of the close method in the Java libraries were wrong in 2007.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“In other words, it is about 50 times slower to create and destroy objects with finalizers.”
― Effective Java : Programming Language Guide
― Effective Java : Programming Language Guide
“premature optimization is the root of all evil. —Donald E. Knuth [”
― Effective Java
― Effective Java
“Builder pattern is more verbose than the telescoping constructor pattern, so it should be used only if there are enough parameters, say, four or more.”
― Effective Java
― Effective Java
“A second advantage of static factory methods is that, unlike constructors, they are not required to create a new object each time they're invoked.”
― Effective Java
― Effective Java