J2ME RecordStore Example


import javax.microedition.midlet.*;
import javax.microedition.lcdui.*;
import javax.microedition.rms.RecordEnumeration;
import javax.microedition.rms.RecordStore;
import javax.microedition.rms.RecordStoreException;

/**
* Preferences Store
*
*Create a class that can persist program preferences. The class will store the preferences into a Record Store.
*Each record will have a variable name and value. Each variable/value pair is stored in a single record.
*The name and value are stored in the database as Strings.
*
*The class should implement these methods:
*public String readVar(RecordStore recStore, String name, String defaultValue)
*public void writeString(RecordStore recStore, String name, String value);
*
* @author calcifer
*
*/

public class PreferenceStore extends MIDlet implements CommandListener{
private Display display;
private Command exit;
private Command write;
private Command read;
private Command back;

private Form inputForm;

private TextBox output = new TextBox("Your Preference:", "", 250, TextField.ANY);
private TextField varName = new TextField("VarName:", "",32,TextField.ANY);
private TextField varValue = new TextField("Value:", "", 32,TextField.ANY);

private RecordStore recStore;

private Alert success;

public PreferenceStore(){
inputForm = new Form("Preference");

exit = new Command("Exit",Command.EXIT, 0);
write = new Command("Write", Command.OK, 0);
read = new Command("Read", Command.OK, 0);
back = new Command("Back", Command.BACK, 0);

output.addCommand(back);
output.setCommandListener(this);

inputForm.append(varName);
inputForm.append(varValue);
inputForm.addCommand(exit);
inputForm.addCommand(write);
inputForm.addCommand(read);
inputForm.setCommandListener(this);

success = new Alert("","Successfully Added!", null, AlertType.INFO);

}

public void startApp() {
try {
recStore = RecordStore.openRecordStore("Preferences", true);
} catch (RecordStoreException ex) {
ex.printStackTrace();
} catch (Exception e){
e.printStackTrace();
}
if(display == null){
display = Display.getDisplay(this);
}
display.setCurrent(inputForm);
}

public void pauseApp() {
}

public void destroyApp(boolean unconditional) {
}

public void commandAction(Command c, Displayable d){
if(c == exit){
notifyDestroyed();
try{
recStore.closeRecordStore();
}catch(Exception e){e.printStackTrace();}
}
else if(c == write){
display.setCurrent(success);
writeString(recStore, varName.getString(), varValue.getString());
varName.setString("");
varValue.setString("");
}
else if(c == read){
output.setString("");
output.setString(readVar(recStore, varName.getString(), varValue.getString()));
display.setCurrent(output);
varName.setString("");
varValue.setString("");
}
else if(c == back){
display.setCurrent(inputForm);
}
}

public void writeString(RecordStore recStore, String name, String value){
String newItem = new String(name + value);

byte[] bytes = newItem.getBytes();
try{
recStore.addRecord(bytes, 0, bytes.length);
}catch(Exception e){ e.printStackTrace();}
}

public String readVar(RecordStore recStore, String name, String defaultValue){
StringBuffer sb = new StringBuffer();

try{
RecordEnumeration enumerator = recStore.enumerateRecords(null, null, true);
while(enumerator.hasNextElement()){
String item = new String(enumerator.nextRecord());
String val = new String(name + defaultValue);
if(item.equals(val))
sb.append(item);
}

}catch(Exception e){e.printStackTrace();}

return sb.toString();
}

}

Read More ..

Interesting Computer Programming Quotes

I'm back! I have here some of the most interesting Computer Programming related quotes. Enjoy! ^^

Programming today is a race between software engineers striving to build bigger and better idiot-proof programs, and the universe trying to build bigger and better idiots. So far, the universe is winning.
* Rick Cook (or Rich Cook?) [citation needed]

The effective exploitation of his powers of abstraction must be regarded as one of the most vital activities of a competent programmer.
* Edsger W. Dijkstra, The Humble Programmer, 1972 Turing Award Lecture, Communications of the ACM 15 (10), (October 1972): pp. 859–866

There is no programming language, no matter how structured, that will prevent programmers from making bad programs.
* Larry Flon

No matter how slick the demo is in rehearsal, when you do it in front of a live audience the probability of a flawless presentation is inversely proportional to the number of people watching, raised to the power of the amount of money involved.
* Mark Gibbs

To me programming is more than an important practical art. It is also a gigantic undertaking in the foundations of knowledge.
* Grace Hopper, quoted in Management and the Computer of the Future (1962) by Sloan School of Management, p. 277

Premature optimization is the root of all evil.
* Donald Knuth, "Structured Programming with Goto Statements". Computing Surveys 6:4 (December 1974), pp. 261–301, §1.

Computer Science is embarrassed by the computer.
* Alan Perlis, "Epigrams on Programming"

Computer programmers never die, they just become lost in the processing.
* Anonymous

Computers can never replace human stupidity.
* Anonymous

Good programming is 99% sweat and 1% coffee.
* Anonymous


Read More ..

Fun Comic Strips

src: http://xkcd.com
Just click the comic strip to view a clearer image of it.
Enjoy! ^^

Game Theory


Qwertial Aphasia




Estimation


Cutting Edge


Extrapolating


Period

Read More ..

Increasing Virtual Memory In XP

I have posted here an easy and affordable tip to solve your 'low memory' problems in Windows XP.

To give you an overview, we are going to increase the system paging file size of your computer. System paging file is also called virtual memory. Virtual memory is part of a secondary memory that is used as if it were primary memory.


To increase the virtual memory of your computer, follow the steps below:

1) Go to 'System Properties' via the 'Control Panel' then click the 'Advanced' tab.

2) Inside the 'Performance Options' panel click the 'Settings' button.


3) Click the 'Advanced' tab then press the 'Change' button.


4) Select the disk volume you would like to use.

5) Set the 'Initial Size' and 'Maximum Size' according to your preference.


That's it, you're done. ^^

Note:
There are some OS's that automatically adjusts the virtual memory for you when you are encountering a 'low memory' problem.

Read More ..

Using The Mouse Pointer Without a Mouse

Do you have problems with your mouse? are you in such a rush that you do not have time to look for a spare and change it? or do you even have a spare?

Here is a handy tip for you.



Left Alt + Left Shift + Num Lock then OK.

This will activate the MouseKeys on your numpad so be sure the LED for NumLock is lit, otherwise it won't work.

The numbers 1,2,3,4,6,7,8 and 9 controls your pointer movement.
Use 5 for clicking. You can change from right-click to left-click through the /,* and - keys on the numpad.


Read More ..

The Pumping Lemma for Regular Languages

src: http://www.seas.upenn.edu/~cit596/notes/dave/pumping2.html
Here's what the pumping lemma says:

* If an infinite language is regular, it can be defined by a dfa.
* The dfa has some finite number of states (say, n).
* Since the language is infinite, some strings of the language must have length > n.
* For a string of length > n accepted by the dfa, the walk through the dfa must contain a cycle.
* Repeating the cycle an arbitrary number of times must yield another string accepted by the dfa.

The pumping lemma for regular languages is another way of proving that a given (infinite) language is not regular. (The pumping lemma cannot be used to prove that a given language is regular.)

The proof is always by contradiction. A brief outline of the technique is as follows:

* Assume the language L is regular.
* By the pigeonhole principle, any sufficiently long string in L must repeat some state in the dfa; thus, the walk contains a cycle.
* Show that repeating the cycle some number of times ("pumping" the cycle) yields a string that is not in L.
* Conclude that L is not regular.

Why this is hard:

* We don't know the dfa (if we did, the language would be regular!). Thus, we have do the proof for an arbitrary dfa that accepts L.
* Since we don't know the dfa, we certainly don't know the cycle.

Why we can sometimes pull it off:

* We get to choose the string (but it must be in L).
* We get to choose the the number of times to "pump."


Read More ..