We are Red Devil !!
Bidur's Rooms
#technology #photography #entrepreneurship #travel #music #HalaMadrid #RedDevil
Saturday, August 27, 2016
Tuesday, June 21, 2016
Peace of Mind
“It's a good idea always to do something relaxing prior to making an important decision in your life.”
― Paulo Coelho, The Pilgrimage |
Monday, June 22, 2015
Sort the content of select element using JavaScript
While I was working for the solution to the scenario that I had to copy list of location from one multiple select element to another. I had an issue that those location were not sorting alphabetically.After some googling and playing around, I come up with following solution
function sortSelectElement(selElement) {
var tmpAry = new Array();
for (var i=0;i<selElement.options.length;i++) {
tmpAry[i] = new Array();
tmpAry[i][0] = selElement.options[i].text;
tmpAry[i][1] = selElement.options[i].value;
}
tmpAry.sort();
while (selElement.options.length > 0) {
selElement.options[0] = null;
}
for (var i=0;i<tmpAry.length;i++) {
var op = new Option(tmpAry[i][0], tmpAry[i][1]);
selElement.options[i] = op;
}
return;
}
Hope it will helps for someone :)
function sortSelectElement(selElement) {
var tmpAry = new Array();
for (var i=0;i<selElement.options.length;i++) {
tmpAry[i] = new Array();
tmpAry[i][0] = selElement.options[i].text;
tmpAry[i][1] = selElement.options[i].value;
}
tmpAry.sort();
while (selElement.options.length > 0) {
selElement.options[0] = null;
}
for (var i=0;i<tmpAry.length;i++) {
var op = new Option(tmpAry[i][0], tmpAry[i][1]);
selElement.options[i] = op;
}
return;
}
Hope it will helps for someone :)
Sunday, May 31, 2015
Monday, December 1, 2014
Is there a shortcut which invokes the “Login Window…” on MAC ? - NO
I got tired of clicking on "Login Windows..." on my mac when I want to lock my logged user account. I discovered a solution to create a easy shortcut command to solve this problem. If you also want to give it a try, you can :)
- Start Applications » Automator
- Select "Service" for the template of the new Automator workflow
- In the top of the right pane, select "Service receives no input in any application"
- Drag action "Run Shell Script" from the left pane into the workflow on the right pane
- Leave Shell at its default "/bin/bash", and replace the default command
cat
with the following, without any line breaks:/System/Library/CoreServices/Menu\ Extras/User.menu/Contents/Resources/CGSession -suspend - Optional: click the Run button to test
- Hit Cmd-S to save. The name you type will be the name in the Services menu. The workflow will be saved in
~/Library/Services
.
To assign a keyboard shortcut, in 10.6:
- Open System Preferences » Keyboard » pane Keyboard Shortcuts
- Select "Services" in the left pane
- Scroll down to General in the right pane
- Double-click to the right of the Automator workflow you just created
- Press the keys you want to use, and switch panes to ensure the new shortcut is saved.
For details please click here.
Sunday, September 28, 2014
Memory Leak
As we know Java is the garbage collected language. Programmer do not need to worry about the memory management. But its not true always.
The memory leak can reduced the performance due to the increased garbage collector activity resulting disk paging and even program failure with an OutOfMemoryError.
Consider the following simple implementation of stack,
import java.util.Arrays;
import java.util.EmptyStackException;
/**
*
* @author
*/
public class Stack {
private Object[] elements;
private int size = 0;
private static final int DEFAULT_INITIAL_CAPACITY = 16;
public Stack() {
elements = new Object[DEFAULT_INITIAL_CAPACITY];
}
public void push(Object e) {
ensureCapacity();
elements[size++] = e;
}
public Object pop() {
if (size == 0) {
throw new EmptyStackException();
}
return elements[--size];
}
/**
* Ensure space for at least one more element, roughly doubling the capacity
* each time the array needs to grow.
*/
private void ensureCapacity() {
if (elements.length == size) {
elements = Arrays.copyOf(elements, 2 * size + 1);
}
}
}
Did you spot the memory leak ?
If the stack grows and then shrinks, the objects that were popped off the stack will not be garbage collected, This is because the stack maintain the absolute reference to these objects.
If an object reference is unintentionally retained, not only object excluded from garbage collection, but also many many objects may be prevented from being garbage collected, with potentially large effect on performance.
Solution : null out the reference once they become obsolete.
public Object popCorrected() {
if (size == 0) {
throw new EmptyStackException();
}
Object result = elements[--size];
elements[size] = null; // Eliminate obsolete reference
return result;
}
The memory leak can reduced the performance due to the increased garbage collector activity resulting disk paging and even program failure with an OutOfMemoryError.
import java.util.Arrays;
import java.util.EmptyStackException;
/**
*
* @author
*/
public class Stack {
private Object[] elements;
private int size = 0;
private static final int DEFAULT_INITIAL_CAPACITY = 16;
public Stack() {
elements = new Object[DEFAULT_INITIAL_CAPACITY];
}
public void push(Object e) {
ensureCapacity();
elements[size++] = e;
}
public Object pop() {
if (size == 0) {
throw new EmptyStackException();
}
return elements[--size];
}
/**
* Ensure space for at least one more element, roughly doubling the capacity
* each time the array needs to grow.
*/
private void ensureCapacity() {
if (elements.length == size) {
elements = Arrays.copyOf(elements, 2 * size + 1);
}
}
}
Did you spot the memory leak ?
If the stack grows and then shrinks, the objects that were popped off the stack will not be garbage collected, This is because the stack maintain the absolute reference to these objects.
If an object reference is unintentionally retained, not only object excluded from garbage collection, but also many many objects may be prevented from being garbage collected, with potentially large effect on performance.
Solution : null out the reference once they become obsolete.
public Object popCorrected() {
if (size == 0) {
throw new EmptyStackException();
}
Object result = elements[--size];
elements[size] = null; // Eliminate obsolete reference
return result;
}
whenever a class manages its own memory, the programmer should be alert for memory leaks.
Another common source of memory leaks is caches.
Source: Effective Java 2nd Edition, Chapter 2
Saturday, September 27, 2014
Design Pattern : Builder
When we have so many parameters in constructor. To deal with this problem we have an alternative to use the Builder pattern. We define a static inner class Builder, whose job it is to collect the parameters and then construct the object in one fell swoop
Example:
public class NutritionFacts {
private final int servingSize;
private final int servings;
private final int calories;
private final int fat;
private final int sodium;
private final int carbohydrate;
public static class Builder {
// Required parameters
private final int servingSize;
private final int servings;
// Optional parameters - initialized to default values
private int calories = 0;
private int fat = 0;
private int carbohydrate = 0;
private int sodium = 0;
public Builder(int servingSize, int servings) {
this.servingSize = servingSize;
this.servings = servings;
}
public Builder calories(int val)
{ calories = val; return this; }
public Builder fat(int val)
{ fat = val; return this; }
public Builder carbohydrate(int val)
{ carbohydrate = val; return this; }
public Builder sodium(int val)
{ sodium = val; return this; }
public NutritionFacts build() {
return new NutritionFacts(this);
}
}
private NutritionFacts(Builder builder) {
servingSize = builder.servingSize;
servings = builder.servings;
calories = builder.calories;
fat = builder.fat;
sodium = builder.sodium;
carbohydrate = builder.carbohydrate;
}
}
Note that NutritionFacts is immutable, and that all parameter default values
are in a single location. The builder’s setter methods return the builder itself so
that invocations can be chained. Here’s how the client code looks:
NutritionFacts cocaCola = new NutritionFacts.Builder(240, 8).
calories(100).sodium(35).carbohydrate(27).build();
This client code is easy to write and, more importantly, to read. The Builder pattern
simulates named optional parameters.
In summary, the Builder pattern is a good choice when designing classes
whose constructors or static factories would have more than a handful of
parameters, especially if most of those parameters are optional.
Source : Effective Java 2nd Edition Chapter 2
Subscribe to:
Posts (Atom)