Saturday, 27 August 2016

Java 8 Method references and Lambda expression


In couple of previous posts we saw use of Lambda expressions - 
 In this post we will see method references, a new feature introduced in Java 8. This is again closely related to Lambda expression. So before you proceed with this post kindly revise above posts on Lambda expressions and make sure you are comfortable using those.

Java 8 Method references

There are 4 types of method references - 
  1. Reference to a static method
  2. Reference to a constructor
  3. Reference to an instance method of an arbitrary object of a particular type
  4. Reference to an instance method of a particular object

Details in diagram below -

 Reference to a static method

Consider following example -

        List<String> employeeNameList = Arrays.asList("Aniket", "Payas","Sudhir","Shivam","Anuj");
        Consumer<List<String>> methodRef1 = Collections::sort;

Output of which is : [Aniket, Anuj, Payas, Shivam, Sudhir]

As you can see we have used reference to static method sort  of class Collections. Here we have used Consumer functional interface that takes a single argument and return type is void.

Lambda analog :

Consumer<List<String>> lambdaRef1 = l -> Collections.sort(l); 

Reference to a constructor

Consider following example - 

        Supplier<ArrayList<String>> methodRef2 = ArrayList::new;
        List<String> newEmployeeNameList = methodRef2.get();

Output of which is : [Aniket, Abhijit]

Here we have used Supplier functional interface whose job is to return a given object type (it does not take any argument). In this case it returns our new ArrayList object.

Lambda analog :

Supplier<ArrayList> lambdaRef2 = () -> new ArrayList();

Reference to an instance method of an arbitrary object of a particular type

Consider following example -

        Predicate<String> methodRef3 = String::isEmpty;
        String emtptyString = "";

Output of which is : true

Here we have used a Predicate  functional interface that take single argument of a type and returns boolean. This may look similar to static method reference but it is not. isEmpty() is not a static but an instance method in String class.

Lambda analog :

Predicate<String> lambdaRef3 = s -> s.isEmpty(); 

Reference to an instance method of a particular object

Consider following example -

        String myName = "Aniket";
        Predicate<String> methodRef4 = myName::contains;

Output of which is : true

Here again we have used Predicate functional interface but notice how here we are using reference of a method in a particular instance rather than a class.

Lambda analog :

Predicate<String> lambda2 = s -> str.contains(s);

NOTE : One thing that is commonn to all method references is deferred execution just like Lambdas. They are just references ready to be executed at a later point in runtime.

NOTE (Common functional interfaces):
  • Predicate : Takes a single paramter of any type and returns a boolean - boolean test(T t)
  • Consumer : Takes a single paramter of any type and has a void return type - void accept(T t)
  • Supplier : Does not take any paramter and returns any type  - T get()
  • UnaryOperator : Takes a single paramter of any type and returns of same type. - R apply(T t)

Related Links

Saturday, 20 August 2016

Resolving issue of losing links when saving word document to PDF in Mac


I had a word document already saved in my dropbox which was initially created on windows I think. When I moved to mac I could open the same document in mac word with links working just fine. Now I edited the doc and exported it as PDF. On opening the PDF I realized the links do not work though it gets displayed a hyperlink in the PDF. After bit of poking around I found out it is an known issue. In this post I provide an alternative approach that worked for me.

Making the links work in PDF

  • I had word document of following format - Microsoft Word 97 - 2004 document - 61 KB
  • Open pages app in your mac and open your word doc in it.

  • Verify all links are working. If you need to edit you can edit it here.
  • Save the opened document as pages document. Its format would be - Pages Publication - 271 KB
  • Next reopen this pages document and go to File -> Export to -> PDF and save it as PDF. Links should work now.

Thursday, 18 August 2016

Installing MongoDB in Mac


Sometime back I had written a post on MongoDB. Installation and basic syntax in Windows - Getting Started with MongoDB . This post is starting of series of posts on MongoDB. In this post we will see installation and configuration of MongoDB in Mac.

Installing MongoDB

  • Go to MongoDb download center and download the tgz of the latest build. Your OS should already be selected and you should see the download link.
  • You can also install MongoDB using homebrew
    • brew install mongodb  (To install the MongoDB binaries)
    • brew install mongodb --with-openssl (To install the MongoDB Binaries with TLS/SSL Support)
    • brew install mongodb --devel  (To install the latest development release)
  • Once you have downloaded that tarball you can unpack it using following command - 
    • tar xvf mongodb-osx-ssl-x86_64-3.2.9.tgz
  • Once you have unpacked it navigate to that folder and then into bin folder inside it. Here you will see list of programs. There are two programs here of out interest - 
    • mongo : This is the mongo shell used to connect to the mongo DB.
    • mongod : This is the actual server.
  • That's it your mongo db is installed and ready to be run.
NOTE : MongoDB by default stores its data in directory "/data/db". So make sure this directory is created with necessary permissions. 
  • sudo mkdir -p /data/db
  • sudo chmod -R 777 /data/

If you want to give a custom path you can give it when you start mongodb - 
  --dbpath arg                          directory for datafiles - defaults to "/data/db"
  • mongod --dbpath /data/mydb

Running and connecting MongoDB

  • To run MongoDB server go to bin directory and start mongod program.
    • ./mongod
  • This should start your mongodb server listening on default port 27017.
  • To see all mongod configuration options you can type - 
    • ./mongod --help

Once mongodb is up you can try connecting to it using mongo shell.
You can start mongo shell by
  • ./mongo
You can also see incoming connection in your server console -
  • 2016-08-18T22:34:27.315+0530 I NETWORK  [initandlisten] connection accepted from #1 (1 connection now open)
Once you are connected you can try following operations - 
  • use mydb
  • db
  • show dbs
  • db.testCollection.insert({"Name":"John"})
  • show collections
  • db.testCollection.find()
 That's it for the basic of installing Mongo DB on your Mac. To avoid always going till bin to execute your programs you can do either of of the follwing -
  1. Add you path to bin to your PATH and export it. OR
  2. Add all these binaries to /usr/local/bin/ by
    • cp * /usr/local/bin
  3. You can verify it by wither running - 
    1. which mongod OR
    2. mongod --help

Related Links

t> UA-39527780-1 back to top