Want to dive even deeper?

Take the course Stairway to Scala Applied III by Bill Venners and Dick Wall and become an expert!
Stairway to Scala Applied III
by Bill Venners , Dick Wall

Check it out!
You're watching a preview of this video, click the button on the left to puchase the full version from Devoxx'10.

Unsung Heroes: Less Fashionable Patterns in Scala

Monads are the talk of the town, and everyone's doing them. In the virtual monad gold-rush, however, have we lost sight of some of the other useful tips, tricks and patterns that have got us to where we are. In this session I will examine a number of useful code snippets and ideas that I have used successfully on many projects, sometimes alongside monads, to great effect. There may be some useful corner cases you have overlooked, or perhaps just would like a refresher in some of the things you may have discovered but then forgotten.

This talk is suitable for Scala beginners but (I hope) will be of use to more experienced Scala developers as well, even if only as a gentle reminder about some of the tricks used, or perhaps in the effective combinations of some of them that have proven useful over time.


Published on
  • 2.882
  • 32
  • 1
  • 15
  • 0
  • Unsung Heroes Useful, Non-monadic Patterns
  • NoMonads? (NoSQL…) ● Not Only Monads ● Why? ● Why Not? ● Occam’s Razor Refresher
  • Monads ● Incredible, Cosmic Power
  • Why Not? ● Overkill ● Monads Don’t Mix ● Ease of Use ● Pragmatism
  • Occam’s Razor
  • The Three Laws of APIs An API Must Work An API Must be Simple An API Can be Clever, but not at the expense of the first two laws * These rules are also a good basis for all software development IMHO
  • The Mighty, Mighty Case Class // Stringly Typed: def lookUpEmpNo(first: String, last: String, branch: String): Int // Case Classes case class Person(first: String, last: String) case class Branch(name: String) case class Employee(person: Person, employeeNumber: Int) def lookUpEmpNo(person: Person, branch: Branch): Employee
  • And Don’t Forget Case Objects def lookupById(id: String, cache: Boolean, remote: Boolean): (String, String) case class EmployeeId(id: String) sealed abstract class IsCached(cached: Boolean) case object Cached extends IsCached(true) case object NotCached extends IsCached(false) sealed abstract class IsRemote(isRemote: Boolean) case object Local extends IsRemote(false) case object Remote extends IsRemote(true) def lookupById(id: EmployeeId, cache: IsCached, remote: IsRemote): Person
  • Loans def withPrintWriter(fileName: String)(fn: PrintWriter => Unit): Unit = { val printWriter = new PrintWriter(fileName) try { fn(printWriter) } finally printWriter.close() } withPrintWriter("hello.txt") { pw => pw.println("Hello, World!") pw.println("Goodbye Cruel World") }
  • Loans def withIterator[A](fileName: String)(fn: Iterator[String] => A): A={ val source = Source.fromFile(fileName) try { val iter = source.getLines() fn(iter) } finally source.close() } withIterator("hello.txt") { iter => iter.map(_.toUpperCase).toList } res5: List[String] = List(HELLO, WORLD!, GOODBYE CRUEL WORLD)
  • But... withIterator("hello.txt") { iter => iter.map(_.toUpperCase) } java.io.IOException: Bad file descriptor withIterator("hello.txt") { iter => iter } java.io.IOException: Bad file descriptor
  • Type Parameters case class DBQuery[T : JsonFormat : Manifest] (designDoc: String, view: String) object DBQuery { def apply[T : JsonFormat : Manifest](view: String) = { val designDoc = manifest[T].runtimeClass.getName DBQuery(designDoc, view) } }
  • Type Parameters def query[T : JsonFormat](dbQuery: DbQuery[T]): Seq[T] = { val results: Seq[String] = databaseQuery(dbQuery.designDoc, dbQuery.view) results.map(_.toJson.convertTo[T]) } // Because... val personQuery = DbQuery[Person]("allByName") val people = query(personQuery)
  • Generic Pattern Matching case class Doohickey[T](item: T, combinerFn: (T, T) => T) { def combineWith(other: Any): Option[T] = other match { case other: T => Some(combinerFn(item, other)) case _ => None } } warning: abstract type pattern T is unchecked since it is eliminated by erasure case other: T => Some(combinerFn(item, other))
  • Generic Pattern Matching scala> val strDoohickey = Doohickey[String]("Hello ", (x, y) => x+y) strDoohickey: Doohickey[String] = Doohickey(Hello ,<function2>) scala> strDoohickey.combineWith("Mum!") res12: Option[String] = Some(Hello Mum!) scala> strDoohickey.combineWith(3) java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String
  • Generic Pattern Matching case class Doohickey[T : ClassTag](item: T, combinerFn: (T,T) => T) { def combineWith(other: Any): Option[T] = other match { case other: T => Some(combinerFn(item, other)) case _ => None } } scala> strDoohickey.combineWith("Mum!") res15: Option[String] = Some(Hello Mum!) scala> strDoohickey.combineWith(8)
  • Generic Pattern Matching def isAListOf[T](x: Any)(implicit ct: ClassTag[T]) = x match { case Nil => "No, this is an empty list" case yes: List[T] if yes.head.getClass == ct.runtimeClass => s"Yes, $yes is a list of ${ct.runtimeClass.getName}" case _ => "No, this is a list of something else" } scala> isAListOf[String](List("hi", "there")) res19: String = Yes, List(hi, there) is a list of java.lang.String scala> isAListOf[String](List(1, 2)) res20: String = No, this is a list of something else
  • Types Again case class StringList(items: List[String]) case class IntList(items: List[Int]) def isAListOfStringOrInt(x: Any) = x match { case StringList(strings) => strings.map(_.toUpperCase).mkString case IntList(ints) => ints.sum.toString } scala> res23: scala> res25: isAListOfStringOrInt(IntList(List(1,2,3))) String = 6 isAListOfStringOrInt(StringList(List("hello", "mum"))) String = HELLOMUM
  • Immutable Builder case class Credentials(user: String, pass: String) case class HttpConnection(server: String, port: Int = 80, ssl: Boolean = false, creds: Option[Credentials] = None) HttpConnection("www.slashdot.org") HttpConnection(server = "localhost", port = 8443, ssl = true, creds = Some(Credentials(user = "dick", pass = "s3curep@ssw0rd")))
  • Immutable Builder case class DefinedSNP(name: String, location: Int, alleles: Set[Char]) case class NamedLocatedSNP(name: String, location: Int) { def alleles(alleles: String) = DefinedSNP(name, location, alleles.toSet) } case class NamedSNP(name: String) { def location(location: Int) = NamedLocatedSNP(name, location) } case object SNP { def named(name: String) = NamedSNP(name) } val theSnp = SNP named "HLA23*" location 1211243 alleles "ATG" theSnp: DefinedSNP = DefinedSNP(HLA23*,1211243,Set(A, T, G))
  • Type Classes import spray.json._ import DefaultJsonProtocol._ case class Color(name: String, red: Int, green: Int, blue: Int) implicit val colorFormat = jsonFormat4(Color) val color = Color("CadetBlue", 95, 158, 160) def printJson[JF : JsonFormat](json: JF): Unit = { val jsonFormat = implicitly[JsonFormat[JF]] // or use implicit parameter println (jsonFormat.write(json)) } printJson(color) {"name":"CadetBlue","red":95,"green":158,"blue":160}
  • State Machine Builders case class DBQuery(designDoc: String, view: String, params: Map[String, JsValue]) { def addParam[JS : JsonWriter](key: String, value: JS) = { val newParams = this.params + (key -> value.toJson) copy(params = newParams) } def reduce(reduce: Boolean): DBQuery = if (reduce) { val newParams = ((params - "group") - "include_docs") + ("reduce" -> reduce.toJson) copy(params = newParams) } else addParam("reduce", reduce) def startKey[JS : JsonWriter](startKey: JS) def endKey[JS : JsonWriter](endKey: JS) def key[JS : JsonWriter](key: JS) def keys[JS : JsonWriter](keys: Seq[JS]) //... } = = = = addParam("startkey", startKey) addParam("endkey", endKey) addParam("key", key) addParam("keys", keys.map(_.toJson).toList)
  • Case with Paired Type Class Companion sealed abstract class AbstractDBObject[O : Manifest] extends JsonFormat[O] { val typeManifest = manifest[O] } def getJson[T : AbstractDBObject](item: T): JsValue = { val dbObjCompanion = implicitly[AbstractDBObject[T]] println("Item manifest " + dbObjCompanion.typeManifest) dbObjCompanion.write(item) }
  • Case with Paired Type Class Companion abstract class DBObject2[T1 : JsonFormat, T2 : JsonFormat, O extends AbstractDBObject[O]{ : Manifest] def apply(v1:T1,v2:T2):O def unapply(o:O):Option[(T1,T2)] implicit val jsonFormat = this def write(o: O): JsValue = { unapply(o) match { case Some((v1, v2)) => JsArray(List(v1.toJson, v2.toJson)) } } def read(value: JsValue): O = ??? // implement here in terms of apply }
  • Case with Paired Type Class Companion case class Person(name: String, age: Int) object Person extends DBObject2[String, Int, Person] def getJson[T : AbstractDBObject](item: T): JsValue = { val dbObjCompanion = implicitly[AbstractDBObject[T]] println("Item manifest " + dbObjCompanion.typeManifest) dbObjCompanion.write(item) } scala> val person = Person("Harry Potter", 27) person: Person = Person(Harry Potter,27) scala> getJson(person) Item manifest $line20.$read$$iw$$iw$$iw$$iw$$iw$$iw$Person res0: spray.json.JsValue = ["Harry Potter",27]
  • Tagged Types type Tagged[U] = { type Tag = U } type @@[T, U] = T with Tagged[U] sealed trait KiloGram def KiloGram[A](a: A): A @@ KiloGram = a.asInstanceOf[A @@ KiloGram] val mass = KiloGram(20.0) mass: @@[Double,KiloGram] = 20.0 2 * mass res1: Double = 40.0
  • Constructor Function Loans class NewBindingModule(fn: MutableBindingModule => Unit) extends BindingModule with Serializable { lazy val bindings = { val module = new Object with MutableBindingModule fn(module) module.freeze().fixed.bindings } } object NewBindingModule { def newBindingModule(fn: MutableBindingModule => Unit): BindingModule = new NewBindingModule(fn) }
  • Constructor Function Loans implicit val bindingModule = newBindingModule { module => import module._ bind [DBLookup] toProvider { module => new MySQLLookup(module) } bind [WebService] to newInstanceOf [RealWebService] bind [Int] idBy 'maxPoolSize toSingle 10 bind [QueryService] toSingle { new SlowInitQueryService } }
  • Parfait trait Db { def name: String } class MySQLDb extends Db { val name = "MySQL" } class PostgresDb extends Db { val name = "Postgres" }
  • Parfait trait WeatherWS { def currentTemp: Double } class ForecastIOWeatherWS extends WeatherWS { def currentTemp = 101.5 } class WeatherDotComWeatherWS extends WeatherWS { def currentTemp = 99.7 }
  • Parfait trait DbConfig { val db: Db } trait WeatherWSConfig { val weather: WeatherWS } trait WholeSystemConfig extends DbConfig with WeatherWSConfig
  • Parfait class DbDoer(implicit config: DbConfig) { val myDbName = config.db.name def getDbName: String = myDbName } class WeatherDoer(implicit config: WeatherWSConfig) { def getCurrentTemp: Double = config.weather.currentTemp } trait TempDoubler { def db: Db // pure abstract - must be provided by implementing class def weather: WeatherWS // likewise // alternatively, def wholeSystemConfig: WholeSystemConfig lazy val getIt: String = s"${db.name} x ${weather.currentTemp * 2}" // still need care with trait init - use lazy }
  • Parfait class TotalSystem(systemName: String)(implicit val config: WholeSystemConfig) extends TempDoubler { val db = config.db val weather = config.weather val dbThing = new DbDoer // implicitly injected with the config for Db val wsThing = new WeatherDoer // ditto, but different config type - WeatherWS def getBoth: String = s"System is $systemName, Db is ${dbThing.getDbName} and temperature is ${wsThing.getCurrentTemp}" val doubleTempAndDB: String = getIt }
  • Parfait class DbWeatherTest extends FunSpec with Matchers { describe ("Using the implicit parameter injection approach") { it ("should work for MySQL and Forecast.io") { implicit object MySQLForecastConfig extends WholeSystemConfig { val db: Db = new MySQLDb val weather: WeatherWS = new ForecastIOWeatherWS } val system = new TotalSystem("Test system 1") system.getBoth should be ("System is Test system 1, Db is MySQL and temperature is 101.5") }
  • Parfait it ("should work for Postgres and Weather.com") { implicit object MySQLForecastConfig extends WholeSystemConfig { val db: Db = new PostgresDb val weather: WeatherWS = new WeatherDotComWeatherWS } val system = new TotalSystem("Test system 2") system.getBoth should be ("System is Test system 2, Db is Postgres and temperature is 99.7") system.doubleTempAndDB should be ("Postgres x 199.4") } } }
  • Q&A ● If there’s time...
  • Tagged Types type Tagged[U] = { type Tag = U } type @@[T, U] = T with Tagged[U] sealed trait KiloGram def KiloGram[A](a: A): A @@ KiloGram = a.asInstanceOf[A @@ KiloGram] val mass = KiloGram(20.0) mass: @@[Double,KiloGram] = 20.0 2 * mass res1: Double = 40.0
Thumbnail for: Refactoring to Functional (slides only)

Refactoring to Functional (slides only)

Hadi Hariri

subscription
Thumbnail for: 10 NoSQL databases you have to know

10 NoSQL databases you have to know

Tom Bujok

subscription
Thumbnail for: Functional Programming: Technical Reasons to Adapt (slides only)

Functional Programming: Technical Reasons to Adapt (slides only)

Venkat Subramaniam

subscription
Thumbnail for: What's New in WildFly 9

What's New in WildFly 9

Tomasz Adamski

subscription
Thumbnail for: PubSub++ - few tips that make your life with kafka easier. (slides only)

PubSub++ - few tips that make your life with kafka easier. (slides only)

Krzysztof Debski

subscription
Thumbnail for: Apache Spark - when things go wrong (slides only)

Apache Spark - when things go wrong (slides only)

Paweł Szulc

subscription
Thumbnail for: My running shoes - Continuous Delivery

My running shoes - Continuous Delivery

Grzegorz Krumpholz

subscription
Thumbnail for: Vaadin Designer, the visual design tool for modern web apps

Vaadin Designer, the visual design tool for modern web apps

Maciej Przepióra

subscription
Thumbnail for: Effective SCRUM in distributed teams (slides only)

Effective SCRUM in distributed teams (slides only)

Rafał Udziela

subscription
Thumbnail for: Get Past the Syntax, The Real Scare is in the Semantics

Get Past the Syntax, The Real Scare is in the Semantics

Venkat Subramaniam

subscription
Thumbnail for: Ścisły przewodnik po aspektach miękkich - część II: Jesteś ekspertem i co dalej? (slides only)

Ścisły przewodnik po aspektach miękkich - część II: Jesteś ekspertem i co dalej? (slides only)

Slawomir Sobotka

free
Thumbnail for: Flavors of Concurrency in Java

Flavors of Concurrency in Java

OLEG ŠELAJEV

free
Thumbnail for: Coding Culture

Coding Culture

Sven Peters

free
Thumbnail for: The end of server management : hosting have to become a commodity (slides only)

The end of server management : hosting have to become a commodity (slides only)

Quentin ADAM

subscription
Thumbnail for: Software architecture as code

Software architecture as code

Simon Brown

subscription
Thumbnail for: Modern Web Architecture

Modern Web Architecture

Ted Neward

subscription
Thumbnail for: HTTP/2 : why upgrading the web? (slides only)

HTTP/2 : why upgrading the web? (slides only)

Quentin ADAM

subscription
Thumbnail for: Failing Continuous Delivery (slides only)

Failing Continuous Delivery (slides only)

Daniel Sawano , Daniel Deogun

subscription
Thumbnail for: A Gentle and useful introduction to Reactive Extensions (slides only)

A Gentle and useful introduction to Reactive Extensions (slides only)

Hadi Hariri

subscription
Thumbnail for: Scalable Is Awesome, Literally! (slides only)

Scalable Is Awesome, Literally! (slides only)

Garrett Smith

subscription
Thumbnail for: From Docker To Kubernetes: A Developer's Guide To Containers (slides only)

From Docker To Kubernetes: A Developer's Guide To Containers (slides only)

Marek Grabowski

subscription
Thumbnail for: Kill the mutants, test your tests

Kill the mutants, test your tests

Roy van Rijn

subscription
Thumbnail for: Unlocking the magic of monads in Java 8

Unlocking the magic of monads in Java 8

OLEG ŠELAJEV

subscription
Thumbnail for: Lazy Evaluations (slides only)

Lazy Evaluations (slides only)

Venkat Subramaniam

subscription
Thumbnail for: Make sense of your (BIG) data! (slides only)

Make sense of your (BIG) data! (slides only)

David Pilato

subscription
Thumbnail for: Painfree Object-Document Mapping for MongoDB

Painfree Object-Document Mapping for MongoDB

Philipp Krenn

subscription
Thumbnail for: Core Software Design Principles for Programmers (slides only)

Core Software Design Principles for Programmers (slides only)

Venkat Subramaniam

subscription
Thumbnail for: Reviewing Architectures

Reviewing Architectures

Nathaniel Schutta

subscription
Thumbnail for: Clean Architecture - how to improve your system architecture

Clean Architecture - how to improve your system architecture

Andrzej Bednarz

subscription
Thumbnail for: Principles Of Microservices

Principles Of Microservices

Sam Newman

subscription
Thumbnail for: Caching reboot: javax.cache & Ehcache 3 (slides only)

Caching reboot: javax.cache & Ehcache 3 (slides only)

Louis Jacomet

subscription
Thumbnail for: Microservices and Conversion Hunting - How to build software architectures for changeableness (slides only)

Microservices and Conversion Hunting - How to build software architectures for changeableness (slides only)

Bernd Zuther

subscription
Thumbnail for: Microservices - enough with theory, let's code some (slides only)

Microservices - enough with theory, let's code some (slides only)

Marcin Grzejszczak , Tomasz Szymanski

subscription
Thumbnail for: User Acceptance Testing - Looking for the Holly Grail (slides only)

User Acceptance Testing - Looking for the Holly Grail (slides only)

Boguslaw Osuch

subscription
Thumbnail for: Vagrant up your enviroment (slides only)

Vagrant up your enviroment (slides only)

Yann Larrivee

subscription
Thumbnail for: Scala and Clojure: Playing well together

Scala and Clojure: Playing well together

David Pollak

subscription
Thumbnail for: The Silver Bullet Syndrome (slides only)

The Silver Bullet Syndrome (slides only)

Hadi Hariri

subscription
Thumbnail for: Security Platform as a Service with Docker and Weave

Security Platform as a Service with Docker and Weave

David Pollak

subscription
Thumbnail for: The Go Language (slides only)

The Go Language (slides only)

Brad Fitzpatrick

subscription
Thumbnail for: Functional Data Storage (slides only)

Functional Data Storage (slides only)

Greg Young

subscription
Thumbnail for: Event Sourcing & Functional Programming - a pair made in heaven

Event Sourcing & Functional Programming - a pair made in heaven

Paweł Szulc

subscription
Thumbnail for: Refactoring meets big money

Refactoring meets big money

Michal Gruca

subscription
Thumbnail for: What's new in Spring Data? (slides only)

What's new in Spring Data? (slides only)

Thomas Darimont

subscription
Thumbnail for: Functional patterns for scala beginners (slides only)

Functional patterns for scala beginners (slides only)

Clément Delafargue

subscription
Thumbnail for: Babun - a Windows shell you will love, finally! (slides only)

Babun - a Windows shell you will love, finally! (slides only)

Tom Bujok , Lukasz Pielak

subscription
Thumbnail for: IDE Wizard? CLI Command? Get both for the price of one! (slides only)

IDE Wizard? CLI Command? Get both for the price of one! (slides only)

Koen Aers

subscription

BigData on Azure for architects – Machine Learning, HDInsight (Hadoop), Event Hub – what to use when (and – how) (slides only)

Tomasz Kopacz

subscription
Thumbnail for: Hystrix – managing failures in distributed systems (slides only)

Hystrix – managing failures in distributed systems (slides only)

Tomasz Nurkiewicz

subscription
Thumbnail for: Deep dive into Reactive Java

Deep dive into Reactive Java

Tomasz Kowalczewski

subscription
Thumbnail for: Nashorn, what is the whole buzz about

Nashorn, what is the whole buzz about

Michal Gruca

subscription
Thumbnail for: Things about microservices you wish you never knew

Things about microservices you wish you never knew

Marek Ko-w

subscription
Thumbnail for: "Bootiful" Microservices with Spring Cloud

"Bootiful" Microservices with Spring Cloud

Josh Long

subscription
Thumbnail for: Is your profiler speaking the same language as you? (slides only)

Is your profiler speaking the same language as you? (slides only)

Simon Maple

subscription
Thumbnail for: Agile Development Meets Connected Devices - Lessons Learned

Agile Development Meets Connected Devices - Lessons Learned

subscription
Thumbnail for: Distributed algorithms for Big Data (slides only)

Distributed algorithms for Big Data (slides only)

DuyHai DOAN

subscription
Thumbnail for: JRebel under the covers - how is it even possible? (slides only)

JRebel under the covers - how is it even possible? (slides only)

Simon Maple

subscription
Thumbnail for: Case Study: Agile @gov.pl (slides only)

Case Study: Agile @gov.pl (slides only)

Matt Harasymczuk

subscription
Thumbnail for: Ansible to rule them all – o provisioningu i deploymencie aplikacji Java

Ansible to rule them all – o provisioningu i deploymencie aplikacji Java

Wojciech Podgorski , Rafal Piotrowski

subscription
Thumbnail for: Supler: complex web forms, not so complex

Supler: complex web forms, not so complex

Adam Warski , Tomasz Szymanski

subscription
Thumbnail for: Deploying Microservice Architectures with Spring Cloud on Cloud Foundry

Deploying Microservice Architectures with Spring Cloud on Cloud Foundry

Pieter Humphrey

subscription
Thumbnail for: 5-10-15 years with Java - from junior to master and back again (slides only)

5-10-15 years with Java - from junior to master and back again (slides only)

Wojciech Seliga

subscription
Thumbnail for: "Bootiful" Applications with Spring Boot

"Bootiful" Applications with Spring Boot

Josh Long

subscription
Thumbnail for: You're an Architect...Now What?

You're an Architect...Now What?

Nathaniel Schutta

subscription
Thumbnail for: Co było pierwsze: kod czy architektura? (slides only)

Co było pierwsze: kod czy architektura? (slides only)

Slawomir Sobotka

subscription
Thumbnail for: From API to protocol (slides only)

From API to protocol (slides only)

Quentin ADAM

subscription
Thumbnail for: Everything Works In Java EE?--Then Try Microservices :-) (slides only)

Everything Works In Java EE?--Then Try Microservices :-) (slides only)

Adam Bien

subscription
Thumbnail for: OAuth2 for native apps and beyond (slides only)

OAuth2 for native apps and beyond (slides only)

Erik Jan de Wit

subscription
Thumbnail for: Building an Asynchronous Reactive NoSQL SDK with RxJava

Building an Asynchronous Reactive NoSQL SDK with RxJava

Simon Baslé

subscription
Thumbnail for: Agile Project Management Anti-Patterns (slides only)

Agile Project Management Anti-Patterns (slides only)

Kasia Mrowca

subscription
Thumbnail for: What's Coming in Java EE 8

What's Coming in Java EE 8

Reza Rahman

subscription
Thumbnail for: WebVR - democracy in Virtual Reality

WebVR - democracy in Virtual Reality

Marcin Lichwala

subscription
Thumbnail for: Why software developers should care about deployment and monitoring

Why software developers should care about deployment and monitoring

Michał Kosmulski

subscription
Thumbnail for: Social Coding - tools and techniques

Social Coding - tools and techniques

Maciej Pleśnar

subscription
Thumbnail for: Applications secure by default (slides only)

Applications secure by default (slides only)

Sławomir Jasek

subscription
Thumbnail for: Busy Java Developer’s Guide to Three REST API Frameworks (slides only)

Busy Java Developer’s Guide to Three REST API Frameworks (slides only)

Ted Neward

subscription
Thumbnail for: High Performance JavaScript Web Apps

High Performance JavaScript Web Apps

Pratik Patel

subscription
Thumbnail for: JCP, Adopt-a-JSR & You

JCP, Adopt-a-JSR & You

Reza Rahman

subscription
Thumbnail for: The Smartwatch Revolution begins: Developing for Android Wear (slides only)

The Smartwatch Revolution begins: Developing for Android Wear (slides only)

Pratik Patel

subscription
Thumbnail for: Wykorzystanie podejścia Domain-Driven Design w systemach legacy (slides only)

Wykorzystanie podejścia Domain-Driven Design w systemach legacy (slides only)

Piotr Wyczesany

subscription
Thumbnail for: Apache Cassandra 101 (slides only)

Apache Cassandra 101 (slides only)

Christopher Batey

subscription
Thumbnail for: The Creative Networker

The Creative Networker

Jurgen Appelo

subscription
Thumbnail for: Using JavaScript/HTML5 Rich Clients with Java EE 7 (slides only)

Using JavaScript/HTML5 Rich Clients with Java EE 7 (slides only)

Reza Rahman

subscription
Thumbnail for: From Docker To Kubernetes: A Developer's Guide To Containers (slides only)

From Docker To Kubernetes: A Developer's Guide To Containers (slides only)

Marek Grabowski

subscription
Thumbnail for: Lessons learned from scaling software

Lessons learned from scaling software

Bartek Nowakowski

subscription
Thumbnail for: Everybody lies

Everybody lies

Tomasz Kowalczewski

free
Thumbnail for: Clean JavaScript code - only dream or reality (slides only)

Clean JavaScript code - only dream or reality (slides only)

Sebastian Łaciak

subscription
Thumbnail for: React.js: Super-fast Single Page Web Applications (slides only)

React.js: Super-fast Single Page Web Applications (slides only)

Pratik Patel

subscription
Thumbnail for: Building fault tolerant microservices

Building fault tolerant microservices

Christopher Batey

subscription
Thumbnail for: Modern Java Component Design with Spring 4.2

Modern Java Component Design with Spring 4.2

Juergen Hoeller

subscription
Thumbnail for: Designing software with security in mind? (slides only)

Designing software with security in mind? (slides only)

Daniel Deogun

subscription
Thumbnail for: From spaghetti with no src/test to green CI, good coverage and well-sleeping developers (slides only)

From spaghetti with no src/test to green CI, good coverage and well-sleeping developers (slides only)

Michał Matłoka , Jacek Kunicki

subscription
Thumbnail for: Technical leadership – from an expert to a leader

Technical leadership – from an expert to a leader

Mariusz Sieraczkiewicz

subscription
Thumbnail for: Modularity in post microservice world

Modularity in post microservice world

Michal Gruca

subscription
Thumbnail for: Level up your dev skills with static analysis

Level up your dev skills with static analysis

David Lindsay

subscription
Thumbnail for: Why I love Logstash and you should too. (slides only)

Why I love Logstash and you should too. (slides only)

João Duarte

subscription
Thumbnail for: Java Bytecode Explained (slides only)

Java Bytecode Explained (slides only)

OLEG ŠELAJEV

subscription
Thumbnail for: Corporate startup and Scala (slides only)

Corporate startup and Scala (slides only)

Filip Rogaczewski

subscription
Thumbnail for: Need for Async: In hot pursuit of internet-scale app architectures

Need for Async: In hot pursuit of internet-scale app architectures

Konrad Malawski

subscription
Thumbnail for: Groovier BDD with Spock (slides only)

Groovier BDD with Spock (slides only)

Michał Kordas

subscription
Thumbnail for: Building systems that are #neverdone

Building systems that are #neverdone

James Lewis

subscription
Thumbnail for: OnConnectionLost: The life of an offline web application

OnConnectionLost: The life of an offline web application

Stefanie Grewenig , Johannes Thönes

subscription