I understand the use for explicitly typed self-references:
trait T {
  self : T2 =>
  ...
}
In the body, self is an alias for this but has the more precise type T with T2.
Now, I've seen this in code:
trait T {
  self =>
  ...
}
That is, an explicit self reference with no additional type information. In this configuration, is there any situation in which self is not just an alias for this? 
It is an alias for this. 
Your first example is useful for ensuring that the trait has been mixed in to an appropriate type, and makes those methods available.
The second example is useful when you have inner classes with naming conflicts, to make the outer scope visible. For example:
trait U {
  self =>
  val name = "outer"
  val b = new AnyRef {
    val name = "inner"
    println(name)
    println(this.name)
    println(self.name)
  }
}
Then new AnyRef with U prints
inner
inner
outer
"self" is not a special keyword - you can use "bananas =>" or whatever you like, but it's often used by convention.
This crops up quite a bit in Swing, where you make a lot on inner classes (textboxes within scrollpanes, etc), which usually have many methods with the same names as the outer classes.
In that case self is a another way of saying this. 
If you happen to have an inner class, however, this inside the inner class would be the inner class, and self would be the container class.
That's the only difference AFAIK
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With