How to play NES games on MacOS?

Hey wasuppp how are you doing guys? I know everything nice today =))

Today I have a look back to Nintendo Entertainment System (NES), some classic games that shaped my childhood, you know “Super mario”? Oh my godness! It’s really amazing that you can actually play most of them in Mac OS (We have another way to play on Windows too!).

The first thing we need to have is OpenEmu (https://openemu.org), just go to the link and download it, decompress the archive then copy it to your Application folder on your Mac.

Open it! the appearance would be looks like this:

Screen Shot 2017-03-18 at 00.35.36.png

Next, now we simply find out NES ROMs from internet, for example, I got some ROMs here: https://www.emuparadise.me/Nintendo_Entertainment_System_ROMs/13

Now from the left side, we choose “Nintendo (NES)”, then drag & drop the downloaded ROMs that you would like to play from this emulator. Then what you can see can be like this after I drag SuperMario to the OpenEmu:

Screen Shot 2017-03-18 at 00.41.46.png

Finally, just double click on it and enjoy your games!

Why String Class is made Immutable or Final in Java?

string1

Performance is a reason. But the MAIN REASON is about SECURITY. Are you surprised about this?
OK I’ll let you know..

Suppose you want to open a secured file which require the user authentication. Let’s say there are two users named huynguyen1 and huynguyen2 and they have their own password files password1 and password2, respectively. Obviously huynguyen2 should not have access to password1 file.
As we know the filenames in Java are specified by using String. Even if you create a File object, passing the name of file as a String only and that String is maintained inside the File object as one of its members.


huynguyen1 could have logged into using his credentials and then somehow could have managed to change the name of his password filename (a String object) from password1 to password2 before JVM actually places the native OS system call to open the file. This would have allowed huynguyen1 to open huynguyen2‘s password file.

Understandably, it would have resulted into a big security flaw in Java. I understand there are so many ‘could have’s here, but you would certainly agree that it would have opened a door to allow developers messing up the security of many resources either intentionally or un-intentionally.

With Strings being immutable, JVM can be sure that the filename instance member of the corresponding File object would keep pointing to same unchanged filename String object. The filename instance member being a final in the File class can anyway not be modified to point to any other String object specifying any other file than the intended one (i.e., the one which was used to create the File object).

Cheers.
Huy Nguyen.

Feel free to contact me via email: contact@alway5.com