Por que as expressões lambda no Java 8 requerem variáveis usadas dentro dele para usar o modificador "final", mas não ao usar a referência de método?

Considere a seguinte classe:

class Foo<T> {

    void handle(T t) {
        System.out.println("handling " + t);
    }

    public static void main(String[] args) {
        List<Integer> list = new ArrayList<>();
        list.add(1);
        list.add(2);

        Foo<Integer> f = new Foo<>();

        list.forEach(f::handle);             // compiles fine
        //list.forEach(obj -> f.handle(obj));// compilation error

        f = new Foo<>(); // reassign f

    }
}

Por que obtenho erro de compilação paraobj -> f.handle(obj), mas não paraf::handle?

questionAnswers(2)

yourAnswerToTheQuestion