Thursday, March 29, 2012
Wednesday, March 28, 2012
Lock and condition java 5 concurrent api
use synchronized keyword
Object monitorObject;
synchronized(monitorObject){
//critical section
}
new way: use Lock.lock() and Lock.unlock()
Lock lockObject;
try{
lockObject.lock();
}
finally{
lockObject.unlock();
}
----
old way: use wait() and notify() in the critical section
//insdie your critical section
boolean somecondition;
while(somecondition){
wait();
}
boolean someOtherCondition;
if(someOtherCondition){
notify();
}
new way: use await() and signal() on condition variables
Condition conditionVariable = lockObject.newCondition();
boolean somecondition;
while(somecondition){
conitionVariable.await();
}
boolean someothercondition;
if(someOtherCondition){
conditionVariable.signal();
}
Thursday, March 22, 2012
Google question
Tell me what you know about security
What is cursor
Tell me about event system
Dealer inventory, what data structure, if large data,how you display partial while getting the whole
Junit ,what things you need pay attention
Wednesday, March 21, 2012
Friday, March 16, 2012
Python ---head first
TAb key Offer suggestion on IDLE
Alt p. alt n previous statements,next statement
array
Movies=["abc",12 ]. Can contain mixed type
Print(movies[1])
Movies.insert(1,sth)
movies.append()
for each_movie in movies
print(each_movie)
while condition:
string either double or single quotes
list of list
isinstance(movies,list)-----true
default recurtion limit 1000
BIF built in function
""" triple quotes add comments
a module is a file ends with.py
Pypi
build a module,distribute it, install
def functionname(arg1,arg2=0) default value make second arg optional
if booleanvariable:
All python code associated with name space
_main_
import nester
import os
os.getcwd() //get current directory
os.chdir(). // change directory
data=open('file.txt')
data.seek(0) // go to beginning of the file
for each line in data
print(each line,end=' ')
(v1,v2)=each line.split(":")
(v1,v2)=each line.split(":",1). //split at most to 2 partseach line.find(":")""" -1 find nothing
except IOError as err:
data.close()
try:
except:""" when no argument ,all exceptions
Or except ValueError:""" concrete exception
except IOError as err
print(str(err)) """ str() can be used to access the stringed representation of any data object that supports the conversion.
finally:
Two type of list, square brackets, you can change, regular brackets, immutable
in for loop, pass like continue in java
if os.path.exist('stretch.txt')
line.strip()""" trimming
out = open("out.txt", "w")
print("egghkk", file=out)
try:
data=open('file.txt')except IOError as err:
finally:
if 'data' in locals() """ locals() returns a collection of variables within the current scope
data.close()
try :
with open('file.txt') as data, open('file1.txt') as data2
When you use with,you don't need worry about closing any open files
---
Pickle
Python ships with standard library called picked, which can save and load almost any Python data object. Once you pickle your data to a file, it is persistent and ready to be read into another program at some later data/time. You can store your pickled data on disk, put it in a database, or transfer it over a network.
when you are ready, reversing this process unpickles your persistent pickled data and recreates your data in its original form within Python's memory.
import pickle
...
try:
with open('mydata.pickle', 'wb') as mysavedata:
pickle.dump([1,2,'three'], mysavedata) """ use dump to save
...
with open('mydata.pickle','rb') as myrestoredata:
a_list = pickle.load(myrestoredata) """ restore the data
except pickle.PickleError as perr:
in-place sorting sort()
Copied sorting sorted()
tt.txt looks like this: 2:34,4-45,2.35
def sanitize(time_string):
if '-' in time_string:
splitter = '-'
if ':' in time time_string:
splitter=':'
else:
return (time_string)
(mins,secs) = time_string.split(splitter)
return(mins+'.'+secs)
with open('tt.txt') as file:
data = file.readline()
list = data.strip().split(',')
cleanlist = []
for item in list
cleanlist.append(sanitize(item))
( this whole thing can be written as cleanlist = [sanitize(item) for item in list] )
print(sorted(cleanlist))
list.pop(1) """ get one element from a list
If you try to add a data item to a set
that already contains the data item, Python simply ignores it.
distances = set()
distances = {10.6, 11, 8, 10.6, "two", 7}
Any duplicates in the supplied list of data values are ignored like 10.6
print(sorted(set([sanitize(t) for t in james]))[0:3])
create dictionary
dictionary1 = {}
dictionary1['Name'] = 'John Cleese'
dictionary1['Occupations'] = ['actor', 'comedian', 'writer', 'film producer']
dictionary2 = dict()
dictionary2= {'Name': 'Michael Palin', 'Occupations': ['comedian', 'actor', 'writer', 'tv']}
---------
define a class
class Athlete:
def __init__(self):
# The code to initialize an "Athlete" object.
create instance
a = Athlete()
When Python processes this line of code, it turns the factory function call into
the following call, which identifies the class, the method (which is automatically
set to __init__()), and the object instance being operated on:
( Athlete.__init__(a) is called)
, not only does the __init__() method require self as its first
argument, but so does every other method defined within your class.
what you write,
d = Athlete("Holy Grail")
d.how_big()
Python executes
Athlete.__init__(d, “Holy Grail”)
Athlete.how_big(d)
, if you save your AthleteList class to a file
called athletelist.py, you can import the into your code
using this line of code:
from athletelist import AthleteList
---------
Python comes with its very own web server,
included in the http.server library module
Here are the five lines of code needed to build a web server in Python.
from http.server import HTTPServer, CGIHTTPRequestHandler
port = 8080
httpd = HTTPServer(('', port), CGIHTTPRequestHandler)
print("Starting simple_httpd on port: " + str(httpd.server_port))
httpd.serve_forever()
data_files = glob.glob("data/*.txt")
form_data = cgi.FieldStorage()
Grab all of the form data and put it in a dictionary
athlete_name = form_data['which_athlete'].value """ which_athlete is a radio button
check which radio button is selected
When your CGI script raises an exception, Python arranges for the error
message to display on STDERR (standard error). The CGI mechanism is
programmed to ignore this output because all it wants is the CGI script’s
standard output.
Python’s standard library comes with a CGI tracking
module (called cgitb) that, when enabled, arranges for detailed error
messages to appear in your web browser.
import cgitb
cgitb.enable()
@property
def top3(self):
return(sorted(set([self.sanitize(t) for t in self]))[0:3])
The use of the @property decorator allows the top3() method to appear
like an attribute to users of the class. So, instead of calling the top3()
method like this:
print(yate.u_list(athletes[athlete_name].top3()))
Treat the top3() method as if it was another class attribute, and call it like
this:
print(yate.u_list(athletes[athlete_name].top3))
The standard library string module
includes a class called Template,
which supports simple string substitutions.
The standard library cgi module
provides support for writing CGI scripts.
ƒ The standard library glob module is
great for working with lists of filenames.
The standard library cgitb module,
when enabled, lets you see CGI coding
errors within your browser.
ƒ Use cgitb.enable() to switch on
CGI tracking in your CGI code.
ƒ Use cgi.FieldStorage() to
access data sent to a web server as part
of a web request; the data arrives as a
Python dictionary.
--
Google provides a cross-platform
Android emulator that lets you develop for the phone as needed
http://developer.android.com/sdk/index.html
Thursday, March 15, 2012
Just Spring reading notes
Today I started reading about Spring.
Dependency Injection (inversion of control)
Provides dependency to your objects at runtime.
Here is the problem:
class DataReaderClient{
FileReader fileReader=new FilerReader();
fileReader.read();
}
in this code, client and reader are tightly coupled together.
improve to:
designing to interfaces
Interface Ireader{
read();
}
class DataReaderClient{
Ireader fileReader=new FilerReader();
fileReader.read();
}
but this is still hardwired, the client has to know which concrete implementation to use.
Spring is to remove this kind of dependency.It works on one single mantra:DI.
When a standalone program starts, it starts the program,creates dependencies,then proceeds to execute the appropriate methods. All dependencies and relationship are created by IoC container and they are injected into the main program as properties.
class DataReaderClient{
Ireader reader=null;
ApplicationContext ctx = null;
public DataReaderClient(){
ctx = new ClassPathXmlApplicationContext("ssss.xml");
}
fetchData(){
reader = (IReader)ctx.getBean("reader");
reader.read();
}
}
sss.xml
------
client will always have to inject a type of IReader, can improve to a service layer
class DataReaderClient{
ReaderService service=null;
ApplicationContext ctx = null;
public DataReaderClient(){
ctx = new ClassPathXmlApplicationContext("ssss.xml");
service = ctx.getBean("readerService");
}
fetchData(){
reader = (IReader)ctx.getBean("reader");
reader.read();
}
}
Tuesday, March 13, 2012
Web container
Web container (also known as a Servlet container) is the component of a web server that interacts with the servlets. A web container is responsible for managing the lifecycle of servlets, mapping a URL to a particular servlet and ensuring that the URL requester has the correct access rights. A web container implements the web component contract of theJava EE architecture, specifying a runtime environment for web components that includes security, concurrency, lifecycle management,transaction, deployment, and other services
Sunday, March 11, 2012
Java IO
Programs use byte streams to perform input and output of 8-bit bytes. All byte stream classes are descended from
InputStream and OutputStream.InputStream.read();
OutputStream.write(c)
both are abstract classes.
FileInputStream in = null; FileOutputStream out = null; try { in = new FileInputStream("xanadu.txt"); out = new FileOutputStream("outagain.txt");Closing a stream when it's no longer needed is very important — so important thatCopyBytesuses afinallyblock to guarantee that both streams will be closed even if an error occurs. This practice helps avoid serious resource leaks.
all other stream types are built on byte streams. --------------All character stream classes are descended fromReaderandWriter.
Reader.read();
Writer.write(c)
Line-Oriented IO has to use bufferedReader and BufferedWriter
--
Above are unbuffered IO,This means each read or write request is handled directly by the underlying OS.
to reduce overhead, the Java platform implements buffered I/O streams.
using wrapping approach
inputStream = new BufferedReader(new FileReader("xanadu.txt")); outputStream = new BufferedWriter(new FileWriter("characteroutput.txt"));Decorator Design pattern!!!-----
Objects of type Scanner are useful for breaking down formatted input into tokens and translating individual tokens according to their data type. s = new Scanner(new BufferedReader(new FileReader("xanadu.txt"))); while (s.hasNext()) { System.out.println(s.next()); }s.useDelimiter(",\\s*");s.hasNextDouble();---Stream objects that implement formatting are instances of eitherPrintWriter, a character stream class, orPrintStream, a byte stream class.System.outis PrintStream
Decorator Pattern
Attaches additional responsibilities to an object dynamically. Decorators provides a flexible alternative to subclassing for extending functionality.
http://javapapers.com/design-patterns/decorator-pattern/
(abstract class) compontent{
m1();
m2();
}
concreteComponent{
m1();
m2();
}
(abstract) Decorator extends component{
m1();
m2();
}
you can use the decorator to decorate concreteComponent to concreteNewComponent with something additional
Design pattern book 95~98
Beverage beverage = new Espresso();
Beverage beverage2 = new DarkRoast();
beverage2 = new Mocha(beverage2);
beverage2 = new Mocha(beverage2); // double mocha
beverage2 = new Whip(beverage2); // with whip cream
HOW PL/SQL GETS EXECUTED
http://comsci.liu.edu/~vasilaky/db2/lec1.htm
the PL/SQL engine on the server where it is compiled. The named PL/SQL
block is compiled only at the time of its creation, or if it has been
changed. The compilation process includes syntax checking, binding,
and p-code generation.
Oracle guarantees a read-consistent view
of the data. Until that point, all data that has been inserted or updated
will be held in memory and only be available to the current user. The
rows that have been changed will be locked by the current user and will
not be available for updating to other users until the locks have been re-leased.
the PL/SQL engine on the server where it is compiled. The named PL/SQL
block is compiled only at the time of its creation, or if it has been
changed. The compilation process includes syntax checking, binding,
and p-code generation.
Oracle guarantees a read-consistent view
of the data. Until that point, all data that has been inserted or updated
will be held in memory and only be available to the current user. The
rows that have been changed will be locked by the current user and will
not be available for updating to other users until the locks have been re-leased.
Saturday, March 10, 2012
Difference between web server and app server
http://www.javaworld.com/javaworld/javaqa/2002-08/01-qa-0823-appvswebserver.html
A Web server exclusively handles HTTP requests, whereas an application server serves business logic to application programs through any number of protocols.
A Web server exclusively handles HTTP requests, whereas an application server serves business logic to application programs through any number of protocols.
Wednesday, March 7, 2012
Monday, March 5, 2012
Servlet basic
SampleServlet extends HttpServlet{
init();
service(httprequest, httpresponse);
}
server engine call service() to handle request, return response.
when the servlet first loaded, init() is called once for initialization
after service() is done, servlet waits till next request
the server can decide to unload this servlet by calling destroy(), you want to
release all the shared resources that were created in init()
two packages
javax.servlet
javax.servlet.http
HttpServlet class methods
service()--serve all requests,defaut implementation is calling doGet, doPost,doDelete,doPut in response to http request
doHeader() defaut calling doGet(), chop off body, only return header
Thread safe Servlet
An application is thread safe if it always behaves predictablly regardless of the number of concurrent threads running in this
process space.
Synchronization in java is the process of locking a variable so that it can be read and modified by only a single thread at a time.
The synchronized keyword eliminates race conditions by locking variables for a specific duration
synchronized(this){
...
..
}
it is possible to synchronize the entire service() method rather than blocks of code, in this way, only on thread at a time
can execute the method. the more code is synchronized, the greater the performance penalty. To aoid this penalty,minimie the amount
of code.
a new servlet object is not instantiated for each new client request, Rather, a single servlet usually services all requests.
This behavior explains how instance variables can often be shared
Because every call to service(), doget(), doPost() is executed in its own thread, variables local to these methods are not shared between
requests and are automatically thread safe.
public class AServlet extends HttpServlet
{
//instance variable
String UserName; // not thread safe
}
public class BServlet extends HttpServlet
{
//instance variable
String userName; // not thread safe
public void service(){
String userName; //thread safe
}
or use SingleThreadModel interface
public class CServlet extends HttpServlet implements SingleThreadModel
{
//instance variable
String userName; // thread safe
}
If servlet implemnts the SinglethreadModel interface, the server guarantees that no more than on thread can execute the service,
doGet, doPost method at a time for a particular servlet instance. this gurantees thread safe.
Http redirects
An Http redirect is a set of instructions included in the header of an Http response that instruct the browser
to issue a new request to a new URL.
An HTTP redirect response uses an HTTP status code of either '301 Moved Permanently" or "302 Moved Temporarily" accompanied
by a Location header containing a valid URL.the browser receives an Http response with status code 301,302,it will
immediately request the resource at the URL designated by the Location Header
sample redirect response
HTTP/1.1 301 Moved Permanently
..
Location:http://www..../....html
sending a redirect with the servlet API
two ways:
service(HttpServletRequest request,HttpServletResponse response){
..
reponse.status(HttpServletResponse.SC_MOVED_PERMANENTLY);
response.setHeader("Location", someurl);
}
or
response.setRedirect(url); //this way only set 302, url has to be full qualified url
Subscribe to:
Comments (Atom)