Monday, December 16, 2013

Difference between Unicode, UTF-8 and UTF-16 (Unicode vs UTF-8 vs UTF-16)

Difference between Unicode, UTF-8 and UTF-16 (Unicode vs UTF-8 vs UTF-16)

Unicode is a character set. UTF-8 and UTF-16 are both encodings of Unicode. 

A character set is a list of characters with unique numbers (these numbers are sometimes referred to as "code points"). For example, in the Unicode character set, the number for A is 41.

An encoding on the other hand, is an algorithm that translates a list of numbers to binary so it can be stored on disk. For example UTF-8 would translate the number sequence 1, 2, 3, 4 like this:

00000001 00000010 00000011 00000100 

Our data is now translated into binary and can now be saved to disk.

All together now

Say an application reads the following from the disk:

1101000 1100101 1101100 1101100 1101111 

The app knows this data represent a Unicode string encoded with UTF-8 and must show this as text to the user. First step, is to convert the binary data to numbers. The app uses the UTF-8 algorithm to decode the data. In this case, the decoder returns this:

104 101 108 108 111 

Since the app knows this is a Unicode string, it can assume each number represents a character. We use the Unicode character set to translate each number to a corresponding character. 

The resulting string is "hello".

Historical Artifact from Microsoft

The development of Unicode was aimed at creating a new standard for mapping the characters in a great majority of languages that are being used today, along with other characters that are not that essential but might be necessary for creating the text. UTF-8 is only one of the many ways that you can encode the files because there are many ways you can encode the characters inside a file into Unicode.

UTF-8 was developed with compatibility in mind. ASCII was a very prominent standard and people who already had their files in the ASCII standard might hesitate in adopting Unicode because it would break their current systems. UTF-8 eliminated this problem as any file encoded that only has characters in the ASCII character set would result in an identical file, as if it was encoded with ASCII. This allowed people to adopt Unicode without needing to convert their files or even changing their current legacy software that was unaware of the Unicode standard. Any of the other mapping methods for Unicode breaks compatibility with ASCII and would force people to convert their system.

The observance of compatibility to ASCII of UTF-8 produces a side-effect that makes it ideal for word processing where most of the time, all the characters being used are included in the ASCII character set. UTF-8 only uses a byte to represent every code point resulting in a file size that is half to the same file encoded in UTF-16 which uses 2 bytes, and a quarter to the same file encoded in UTF-32 which uses 4.

UTF-8 has been adopted in the World Wide Web because it is both space efficient and byte oriented. Web pages are often simple text files that usually do not contain any character that is outside the ASCII character set. Using other encoding methods would only increase the network load without any benefit. Even in email transport systems, UTF-8 is slowly but surely being adopted as a replacement for the older encoding systems that are still being used.

Summary:

1. Unicode is the standard for computers to display and manipulate text while UTF-8 is one of the many mapping methods for Unicode. 

2. UTF-8 is a mapping method the retains compatibility with the older ASCII

3. UTF-8 is the most space efficient mapping method for Unicode compared to other encoding methods

4. UTF-8 is the most used Unicode standard for the web

Conclusion

UTF-8 and Unicode cannot be compared. UTF-8 is an encoding used to translate binary data into numbers. Unicode is a character set used to translate numbers into characters.

Wednesday, December 4, 2013

Very Important Last Interview Question: Do you have any question for me?

Very Important Last Interview Question: Do you have any question for me?

If you are going for any interview, you must know that at the end of the interview, after asking many questions from you, the interviewer will allow you to ask questions from him. Last question of the interview will be: "Do you have any question for me?". And, my advice is that you must prepare this very last question beforehand.

When the interviewer asks if the candidate has any questions and the answer is none it can be perceived as a low interest level in taking up the job offered.

The questions by the candidate should show a sound knowledge of the company and the overall responsibilities of the offered position. A confident candidate would always want to know more about the organization, in terms of work culture, growth prospects, organizational values, team work and an inside view of the job profile.

The following are the questions the interviewer would be happy to hear from an interviewee, because the interviewer feels this would be what a clear thinking, success oriented candidate would want to know.

Below is the list of the questions you must prepare to ask from interviewer at the end of the interview:

1. Is your company growing and what are the prospects of future expansion?

2. What difficulties do new employees experience in adapting to your company's environment?

3. What are the primary success factors of this role?

4. Might there be other ways I can contribute to the business with my skill sets?

5. Should I be successful, what are the opportunities for advancement?

6. What should I expect with regard to feedback?

7. Will I have an opportunity to create a development plan to be coached on throughout the year?

8. What emphasis is placed on teams working together?

Tuesday, December 3, 2013

26 A-Z Small but Important Tips for Cracking your Job Interview

26 A-Z Small but Important Tips for Cracking your Job Interview

Are you preparing for your job interview in your dream company? Best of luck!! Following are 26 small but important job interview tips arranged in alphabetical order from A to Z. Please go through all job interview tips once before appearing for any interview in any field for any position.

A – Anticipate key questions and have answers ready 

B – Bring the information you will need to fill out an application (references, dates, Social Security Number, etc.) 

C – Connect your past work experience to the present position you are interviewing for 

D – Don’t criticize your previous employer; it will leave a bad impression 

E – Eye contact with the interviewer shows confidence 

F – Fill in all blanks on the application (except the salary blank) 

G – Get there 15-20 minutes early; NEVER be late! 

H – Handshake should be firm 

I – Incorporate specific examples of your successes 

J – Job responsibilities that you excelled at in your past experience should be discussed and related to the position you are interviewing for whenever possible 

K – Know the directions to the building (drive a practice run if you must) 

L – Legs should not be crossed; maintain open/receptive body language 

M – Mail them a thank you letter afterwards. Make this letter short, professional, and to the point. Thank them for their time and that you look forward to the opportunity to become part of their organization 

N – NEVER LIE! Answer all questions truthfully and frankly, but don’t “over answer” either 

O – Opportunity is the focus…not money. Be prepared to discuss the opportunity and how you can make a positive impact in the company. Never focus on how much money you can make or ask about financial compensation during the interview 

P – Professional attire is a must – even if you know the environment is casual, the interview is formal 

Q – Quality of work and a strong understanding of the core skills you are interviewing for are quintessentially important. 

R – Research the company and have questions prepared about it 

S – Sit upright, look alert and interested at all times 

T – Take a portfolio to take notes in (blue or black ink only) 

U – Update your resume and have 3 references before you go on the interview 

V – Vacation days should not be discussed but the value you bring to the company is a great focal point 

W – Wear a watch; even if it is broken, it will give you the illusion of being organized and prompt 

X –Xerox multiple copies of your resume in case you meet with more interviewers than you had expected 

Y – Yes or no answers to questions are not good enough; providing a short explanation of your answers proves your knowledge and experience 

Z – Zero in on what benefits you bring to the company 

Difference between CreateProcess and ShellExecute API Calls

Difference between CreateProcess and ShellExecute API Calls

CreateProcess and ShellExecute API Calls are very useful and closely related. In this article, I have tried to make clear the difference between CreateProcess and ShellExecute API Calls. You should know where and why to use CreateProcess and ShellExecute API Calls in your application. So here are some points of difference between CreateProcess and ShellExecute API Calls.

1. CreateProcess() is more oriented on low level and ShellExecute() on the high user level:

For example using of CreateProcess with correct parameters you can start the program which has the path larger as MAX_PATH. It has 32,768 characters restriction. You can also use CreateProcess to start program (if you have enough permissions) on another windows desktop like on the Logon Screen.

Another example: You can use ShellExecute to start Control Panel or open any program which existed on the computer for editing of JPG file for example. So you work with ShellExecute close to the corresponding actions in the Windows Explorer.

2. ShellExecute() is more flexible than CreateProcess(): An extension of my first point

ShellExecute() is a shell around the OS and defaults to the OS to run programs, which gives it a lot more flexibility than CreateProcess(), which engages the program directly, which is why you can't run, say, HTML files, or PDF files, etc., with CreateProcess(), but which can be run with ShellExecute().

ShellExecute() is a wrapper to the process of:

1. Determining the type of file by searching the Windows Registry.
2. Enumerating the allowed shell commands (verbs).
3. Retrieving the command line for the specified verb.
4. Constructing the command-line switches.
5. Calling CreateProcess() to start the process pointed to by the retrieved command line.

3. Handle Information

CreateProcess returns the handle and id for the started process and it's main thread in the PROCESS_INFORMATION structure. By using these handles, you can shut down the process whenever required but no handle is returned by ShellExecute().

Suggestion: If you just want to launch a file in a browser or notepad etc., ShellExecute() is probably what you want. However, if you know the exact .exe name you want to launch, using CreateProcess() gives you much more control.

Note: Do not use WinExec() as it is a deprecated function from the 16-bit days.

How to use CreateProcess API Call to create and execute a new process in Delphi XE4?

How to use CreateProcess API Call to create and execute a new process in Delphi XE4?

Executing a program or process in Win32 means loading a process and its child thread(s) in memory. CreateProcess is used to create and run the process in Win32. We will see how to use CreateProcess in Delphi XE4 to execute an exe? For backward compatibility, the Win16 calls for executing programs, WinExec and ShellExecute are still supported in the Windows API, and still work. But for 32-bit programs, they're considered obsolete.

The following code utilizes the CreateProcess API call, and will execute any program, DOS or Windows.

procedure ExecuteNewProcess(ProgramName : String; Wait: Boolean);
var
  StartInfo : TStartupInfo;
  ProcInfo : TProcessInformation;
  CreateOK : Boolean;
begin 
  FillChar(StartInfo,SizeOf(TStartupInfo),#0);
  FillChar(ProcInfo,SizeOf(TProcessInformation),#0);
  StartInfo.cb := SizeOf(TStartupInfo);
  
  CreateOK := CreateProcess(nil, PChar(ProgramName), nil, nil,False,
              CREATE_NEW_PROCESS_GROUP+NORMAL_PRIORITY_CLASS,
              nil, nil, StartInfo, ProcInfo);

  try
    if CreateOK then //Check if the process is created successfully
    begin
      if Wait then WaitForSingleObject(ProcInfo.hProcess, INFINITE); //Load children processes
    end
    else
    begin
      ShowMessage('Unable to run '+ProgramName);
    end;
  finally
    CloseHandle(ProcInfo.hProcess);
    CloseHandle(ProcInfo.hThread);
  end;
end;

In above code, I will pass an executable file to ExecuteNewProcess method lets say abc.exe.

Relation between Threads and Processes

Here it is very important to mention the relation between threads and processes. Threads are children of processes; while processes, on the other hand, are inert system entities that essentially do absolutely nothing but define a space in memory for threads to run - threads are the execution portion of a process and a process can have many threads attached to it. So, we can say, processes are merely memory spaces for threads.

Sunday, December 1, 2013

iPhone Basic Interview Questions and Answers for Developers

iPhone Basic Interview Questions and Answers for Developers 

If you are preparing for iPhone technical interview, you must go through following iPhone interview questions and answers which are very basic for an iPhone developer and you should know all these basic iPhone concepts. Following iPhone interview questions and anwsers cover basic iPhone concepts like iPhone OS, SDK, Architecture, MVC design pattern, COCOA, COCOA Touch, Objective C, Shallow and Deep Copy in Objective C, difference between implementing a category and inheritance, Apple push notification service, When to use NSMutableArray and when to use NSArray, difference between frame and bounds, UIWindow object, Garbage collector in iPhone, nonatomic, @synthesize, delegate methods of MKMapView, types of parser and lot more...Lets have look on these iPhone basic interview questions and answers. 

1. What is iPhone OS? 

iPhone OS runs on iPhone and iPod touch devices. Hardware devices are managed by iPhone OS and provides the technologies needed for implementing native applications on the phone. The OS ships with several system applications such as Mail, Safari, Phone, which provide standard services to the user. 

2. What is iPhone SDK?

iPhone SDK is available with tools and interfaces needed for developing, installing and running custom native applications. Native applications are built using the iPhone OS’s system frameworks and Objective-C language and run directly on iPhone OS. Native applications are installed physically on a device and can run in presence or absence of network connection.

3. What is iPhone Architecture? 

It is similar to MacOS X architecture. It acts as an intermediary between the iPhone and iPod hardware an the appearing applications on the screen. The user created applications never interact directly with the appropriate drivers, which protects the user applications from changes to the hardware.

4. What is MVC ? MVC Architecture of iPhone App.

Here are the reasons why we should use the MVC (Model View Controller)design pattern.
    
1. MVC is resuable: When the problems occurs, there is no need to invent a new solution, we just have to follow the pattern and adopt it as necessary.
    
2. MVC is expressive: By using the MVC design pattern our application becomes more expressive.

1).  Model: The model object knows about all the data that need to be displayed. It is model who is aware about all the operations that can be applied to transform that object. It only represents the data of an application. The model represents enterprise data and the business rules that govern access to and updates of this data. Model is not aware about the presentation data and how that data will be displayed to the browser.

2). View: The view represents the presentation of the application. The view object refers to the model. It uses the query methods of the model to obtain the contents and renders it. The view is not dependent on the application logic. It remains same if there is any modification in the business logic. In other words, we can say that it is the responsibility of the of the view's to maintain the consistency in its presentation when the model changes.

3). Controller:  Whenever the user sends a request for something then it always go through the controller. The controller is responsible for intercepting the requests from view and passes it to the model for the appropriate action. After the action has been taken on the data, the controller is responsible for directing the appropriate view to the user. In  GUIs, the views and the controllers often work very closely together.

5. What are the ways to store data localy on iPhone device?

We store data localy in device through:

1. Plist.
2. NSUserDefaults.
3. SQLite.
4. CoreData.

6. Difference between COCOA, COCOA touch and objective C?

Objective C is a dynamic programming language - a bit like C++ and a bit like Java.

Cocoa is the application framework for Mac OS X. Cocoa Touch is the application framework for iPhone and iPod Touch - very similar to Cocoa. 

Cocoa is commonly referred to as the combination of the Foundation and AppKit frameworks, while Cocoa Touch is the combination of the Foundation and UIKit frameworks. Cocoa and Cocoa Touch sit on top of other collections of frameworks to create the API stacks. The other layers are Media, Core Services and Core OS. The main difference between Cocoa and Cocoa touch is that the UI classes and APIs aren't the same as Mac OS X, so instead of NSTextField, you have UITextField. Many of the classes share the same functionality and can be ported quite easily by simply changing the class name, though most will require some more changes, but usually nothing too heavy. There are also some differences between the Foundation frameworks in Cocoa and Cocoa Touch, most commonly missing classes, eg, Cocoa has NSHost and Cocoa Touch doesn't.

7. Difference between shallow copy and deep copy?

Shallow copy is also known as address copy. In this process you only copy address not actual data while in deep copy you copy data. Suppose there are two objects A and B. A is pointing to a different array while B is pointing to different array. Now what I will do is following to do shallow copy.?Char *A = {‘a’,’b’,’c’};?Char *B = {‘x’,’y’,’z’};?B = A;?Now B is pointing is at same location where A pointer is pointing.Both A and B in this case sharing same data. if change is made both will get altered value of data.Advantage is that coping process is very fast and is independent of size of array.while in deep copy data is also copied. This process is slow but Both A and B have their own copies and changes made to any copy, other will copy will not be affected.

8. What is advantage of categories? What is difference between implementing a category and inheritance? 

You can add method to existing class even to that class whose source is not available to you. You can extend functionality of a class without subclassing. You can split implementation in multiple classes. While in Inheritance you subclass from parent class and extend its functionality.

9. Flow of push notification? 

Ans. Your web server sends message (device token + payload) to Apple push notification service (APNS) , then APNS routes this message to device whose device token specified in notification.

10. What is polymorphism?

This is very famous question and every interviewer asks this. Few people say polymorphism means multiple forms and they start giving example of draw function which is right to some extent but interviewer is looking for more detailed answer. Ability of base class pointer to call function from derived class at runtime is called polymorphism. For example, there is super class human and there are two subclasses software engineer and hardware engineer. Now super class human can hold reference to any of subclass because software engineer is kind of human. Suppose there is speak function in super class and every subclass has also speak function. So at runtime, super class reference is pointing to whatever subclass, speak function will be called of that class. I hope I am able to make you understand.

11. When to use NSMutableArray and when to use NSArray?

Ans. Normally we use mutable version of array where data in the array will change. For example, you are passing a array to function and that function will add some elements to that array or will remove some elements from array, then you will select NSMutableArray. When you don’t want to change you data, then you store it into NSArray. For example, the country names you will put into NSArray so that no one can accidentally modify it.

12. How is the app delegate is declared by Xcode project templates?

App delegate is declared as a subclass of UIResponder by Xcode project templates.

13. What is the purpose of UIWindow object?

The presentation of one or more views on a screen is coordinated by UIWindow object.

14. Whats the difference between frame and bounds?

The frame of a view is the rectangle, expressed as a location (x,y) and size (width,height) relative to the superview it is contained within. The bounds of a view is the rectangle, expressed as a location (x,y) and size (width,height) relative to its own coordinate system (0,0).

15. What is @interface?

It’s a keyword used to declare the Class.

16. What is @implementation?

It’s a keyword used to define the Class.

17. Garbage collector in iPhone?

iOS has got the ARC ( Automated reference counting ). Objective C does not have a garbage collector rather it uses the reference counting algorithm to manage the memory. This was the developers task until Apple launched iOS 5.0. Again if you are targeting iOS 4.0 or earlier , ARC is no more a choice for you.

18. What is delegate?

Delegate is an object that handles the events happening on an object. To do that delegate has to follow a protocol specifying the task it is going to handle.

19. What is @synthesize?

We use @synthesize to generate getters and setters automatically from compiler. We declare properties and then generate getter and setter method by using @synthesize.

20. What is nonatomic?

nonatomic and atomic are related to multithreading environment . If a property has an attribute as “nonatomic” that means multiple threads can modify that property concurrently. If the attribute is “atomic”, the threads would be given access atomically. So “Atomic” is thread safe while “nonatomic” is thread unsafe. Atomic drastically hampers the performance so until and unless not needed you should never go for atomic attribute. ‘nonatomic ’ will do in most of the cases.

21. What are the delegate methods of MKMapView?

Firstly you have added the storeKit framework in your xcode project then define the protocol as <MKMapviewDelegate> in .h file.

- (void)mapView:(MKMapView *)mapView regionWillChangeAnimated:(BOOL)animated;
- (void)mapView:(MKMapView *)mapView regionDidChangeAnimated:(BOOL)animated;
- (void)mapViewWillStartLoadingMap:(MKMapView *)mapView;
- (void)mapViewDidFinishLoadingMap:(MKMapView *)mapView;
- (void)mapViewDidFailLoadingMap:(MKMapView *)mapView withError:(NSError *)error;
- (MKAnnotationView *)mapView:(MKMapView *)mapView viewForAnnotation:(id <MKAnnotation>)annotation;
- (void)mapView:(MKMapView *)mapView didAddAnnotationViews:(NSArray *)views;

22. What are the important delegate methods of NSXML parser?

-DidStartElement
-FoundCharecters
-DidEndElement
-FoundError

23. What is @dynamic and any place where it is used?

It tells compiler that getter and setter are not implemented by the class but by some other class.   
May be super class or child class.
Example – Core Data. 
- The Managed object classes have properties defined by using @dynamic.

24. Types of parsers?

There are various parsers available to parse an XML in iOS app development. You can choose either from iOS SDK provided by Apple or from third party libraries. Before discussing about various options, I want to highlight difference between XML parsers. Generally two types of parsers are used in XML parsing: SAX and DOM. Let's have a look at their brief description.

SAX parser- This parser is based on some notifying methods. These methods are notified as the SAX parser moves on the XML document. During the parsing activity, developer is responsible to construct required object and keep track of state of the XML parser. Some examples of this parser are as follows-

NSXMLParser - It is written in Objective-C and provided by Apple through its iOS SDK.

libxml2 - It is based on C language API and also provided by Apple through its iOS SDK. It supports both SAX and DOM parser.

DOM parser- This parser parse the complete document in a single go and converts it into a specific structured object. We can create XPath query for a particular element from this structured object. Some examples of this parser are as follows-

TBXML- It's a lightweight XML parser designed in such a way to consume very low memory. It's a good choice for an XML as well as that have the fixed structure.

TouchXML - It is another DOM parser. It is also read only but does not support XPath queries.

KissXML - It is based on TouchXML parser. It supports editing and writing XML unlike TouchXML parser.

TinyXML - It is very small DOM parser and based on C language API. It supports editing and writing XML documents like KissXML parser but does not support XPath queries.

GDataXML - It is developed by Google using Objective-C API. It supports both editing of XML documents and XPath queries.

Saturday, November 30, 2013

PHP Basic Interview Questions and Answers for Web Developers - Part 1

PHP Basic Interview Questions and Answers for Web Developers - Part 1

In this article on PHP Interview Questions, I have compiled a list of very basic and fundamental PHP interview questions and answers for web developers. Every PHP web developer should know these basic questions of PHP. So, if you are preparing for any interview in PHP development, you should go through the following list of PHP basic interview questions. There PHP questions are based on very simple PHP concepts like basic introduction to PHP, Sessions and Cookies in PHP, Input / Output in PHP, Error Management in PHP, MySQL database connectivity in PHP, SQL Injection in PHP, Encryption and Decryption in PHP, Sending Emails in PHP, datatypes in PHP and many more. Lets have a look...

1. What is PHP?

PHP is a server side scripting object oriented language commonly used for web applications. 

2. What is the use of "echo" in php?

It is used to print a data in the webpage.

Example: 

<?php echo 'Hi'; ?>

The above code print the text in the webpage

3. How to include a file to a php page?

We can include a file using "include()" or "require()" function with file path as its parameter.

4. What's the difference between include and require?

If the file is not found by require(), it will cause a fatal error and halt the execution of the script. If the file is not found by include(), a warning will be issued, but execution will continue.

5. What is difference between require_once(), require() and include()?

require() includes and evaluates a specific file, while require_once() does that only if it has not been included before (on the same page). So, require_once() is recommended to use when you want to include a file where you have a lot of functions for example. This way you make sure you don't include the file more times and you will not get the "function re-declared" error.

6. Differences between GET and POST methods?

We can send 1024 bytes using GET method but POST method can transfer large amount of data and POST is the secure method than GET method .

7. How to declare an array in php?

Eg : var $arr = array('apple', 'grape', 'lemon');

8. What is the use of 'print' in php?

This is not actually a real function, It is a language construct. So you can use without parentheses with its argument list.

Example:

print('PHP Interview Questions'); 
print 'PHP Interview Questions';

9. What is use of in_array() function in php?

in_array used to checks if a value exists in an array

10. What is use of count() function in php?

count() is used to count all elements in an array, or something in an object

11. What is the difference between Session and Cookie?

The main difference between sessions and cookies is that sessions are stored on the server, and cookies are stored on the user’s computers in the text file format. Cookies can not hold multiple variables, but Session can hold multiple variables. We can set expiry for a cookie while the session only remains active as long as the browser is open. Users do not have access to the data you stored in Session because it is stored in the server. Session is mainly used for login/logout purpose while cookies using for user activity tracking

12. How to set cookies in PHP?

Setcookie("sample", "ram", time()+3600);

13. How to retrieve a Cookie Value?

eg : echo $_COOKIE["user"];

14. How to create a session? How to set a value in session ? How to remove data from a session?

Create session : session_start();
Set value into session : $_SESSION['USER_ID']=1;
Remove data from a session : unset($_SESSION['USER_ID'];

15. What types of loops exist in php?

for,while,do while and foreach 

16. How to create a mysql connection?

mysql_connect(servername,username,password);

17. How to select a database?

mysql_select_db($db_name);

18. How to execute an sql query? How to fetch its result ?

$my_qry = mysql_query("SELECT * FROM `users` WHERE `u_id`='1'; "); 
$result = mysql_fetch_array($my_qry);
echo $result['First_name'];

19. Write a program using while loop

$my_qry = mysql_query("SELECT * FROM `users` WHERE `u_id`='1'; "); 
while($result = mysql_fetch_array($my_qry))
{
   echo $result['First_name'.]."<br/>";
}

20. How we can retrieve the data in the result set of MySQL using PHP?

1. mysql_fetch_row
2. mysql_fetch_array
3. mysql_fetch_object
4. mysql_fetch_assoc

21. What is the use of explode() function?

Syntax : array explode ( string $delimiter , string $string [, int $limit ] ); 

This function breaks a string into an array. Each of the array elements is a substring of string formed by splitting it on boundaries formed by the string delimiter.

22. What is the difference between explode() and split() functions?

Split function splits string into array by regular expression. Explode splits a string into array by string.

23. What is the use of mysql_real_escape_string() function?

It is used to escapes special characters in a string for use in an SQL statement

24. Write down the code for save an uploaded file in php.

if ($_FILES["file"]["error"] == 0)
{
       move_uploaded_file($_FILES["file"]["tmp_name"],
      "upload/" . $_FILES["file"]["name"]);
      echo "Stored in: " . "upload/" . $_FILES["file"]["name"]; 
}

25. How to create a text file in php?

$filename = "/home/user/guest/newfile.txt";
$file = fopen( $filename, "w" );
if( $file == false )
{
echo ( "Error in opening new file" ); exit();
}
fwrite( $file, "This is a simple test\n" );
fclose( $file );

26. How to strip whitespace (or other characters) from the beginning and end of a string?

The trim() function removes whitespaces or other predefined characters from both sides of a string.

27. What is the use of header() function in php?

The header() function sends a raw HTTP header to a client browser.Remember that this function must be called before sending the actual out put.For example, You do not print any HTML element before using this function.

28. How to redirect a page in php?

The following code can be used for it, header("Location:index.php");

29. How stop the execution of a php script?

exit() function is used to stop the execution of a page

30. How to set a page as a home page in a php based site?

index.php is the default name of the home page in php based sites

31. How to find the length of a string?

strlen() function used to find the length of a string

32. What is the use of rand() in php?

It is used to generate random numbers.If called without the arguments it returns a pseudo-random integer between 0 and getrandmax(). If you want a random number between 6 and 12 (inclusive), for example, use rand(6, 12).This function does not generate cryptographically safe values, and should not be used for cryptographic uses. If you want a cryptographically secure value, consider using openssl_random_pseudo_bytes() instead.

33. What is the use of isset() in php?

This function is used to determine if a variable is set and is not NULL

34. What is the difference between mysql_fetch_array() and mysql_fetch_assoc()?

mysql_fetch_assoc function Fetch a result row as an associative array, While mysql_fetch_array() fetches an associative array, a numeric array, or both

35. What is mean by an associative array?

Associative arrays are arrays that use string keys is called associative arrays.

36. What is the importance of "method" attribute in a html form?

"method" attribute determines how to send the form-data into the server.There are two methods, get and post. The default method is get.This sends the form information by appending it on the URL.Information sent from a form with the POST method is invisible to others and has no limits on the amount of information to send.

37. What is the importance of "action" attribute in a html form?

The action attribute determines where to send the form-data in the form submission.

38. What is the use of "enctype" attribute in a html form?

The enctype attribute determines how the form-data should be encoded when submitting it to the server. We need to set enctype as "multipart/form-data" when we are using a form for uploading files

39. How to create an array of a group of items inside an HTML form?

We can create input fields with same name for "name" attribute with squire bracket at the end of the name of the name attribute, It passes data as an array to PHP. 

For instance :

<input name="MyArray[]" />  <input name="MyArray[]" />  <input name="MyArray[]" />  <input name="MyArray[]" />

40. Define Object-Oriented Methodology.

Object orientation is a software/Web development methodology that is based on the modeling a real world system.An object is the core concept involved in the object orientation. An object is the copy of the real world enity.An object oriented model is a collection of objects and its inter-relationships

41. How do you define a constant?

Using define() directive, like define ("MYCONSTANT",150)

42. How send email using php?

To send email using PHP, you use the mail() function.This mail() function accepts 5 parameters as follows (the last 2 are optional). You need webserver, you can't send email from localhost. eg : mail($to,$subject,$message,$headers);

43. How to find current date and time?

The date() function provides you with a means of retrieving the current date and time, applying the format integer parameters indicated in your script to the timestamp provided or the current local time if no timestamp is given. In simplified terms, passing a time parameter is optional - if you don't, the current timestamp will be used.

44. Difference between mysql_connect and mysql_pconnect?

There is a good page in the php manual on the subject, in short mysql_pconnect() makes a persistent connection to the database which means a SQL link that do not close when the execution of your script ends. mysql_connect()provides only for the databasenewconnection while using mysql_pconnect , the function would first try to find a (persistent) link that's already open with the same host, username and password. If one is found, an identifier for it will be returned instead of opening a new connection... the connection to the SQL server will not be closed when the execution of the script ends. Instead, the link will remain open for future use.

45. What is the use of "ksort" in php?

It is used for sort an array by key in reverse order.

46. What is the difference between $var and $$var?

They are both variables. But $var is a variable with a fixed name. $$var is a variable who's name is stored in $var. For example, if $var contains "message", $$var is the same as $message.

47. What are the encryption techniques in PHP?

MD5: PHP implements the MD5 hash algorithm using the md5 function.

eg : $encrypted_text = md5 ($msg);

mcrypt_encrypt: string mcrypt_encrypt ( string $cipher , string $key , string $data , string $mode [, string $iv ] ); 

Encrypts plaintext with given parameters

48. What is the use of the function htmlentities?

htmlentities Convert all applicable characters to HTML entities This function is identical to htmlspecialchars() in all ways, except with htmlentities(), all characters which have HTML character entity equivalents are translated into these entities.

49. How to delete a file from the system?

Unlink() deletes the given file from the file system.

50. How to get the value of current session id?

session_id() function returns the session id for the current session.

51. What are the differences between mysql_fetch_array(), mysql_fetch_object(), mysql_fetch_row()?

Mysql_fetch_array Fetch a result row as an associative array, a numeric array, or both.
mysql_fetch_object ( resource result ) Returns an object with properties that correspond to the fetched row and moves the internal data pointer ahead. Returns an object with properties that correspond to the fetched row, or FALSE if there are no more rows
mysql_fetch_row() fetches one row of data from the result associated with the specified result identifier. The row is returned as an array. Each result column is stored in an array offset, starting at offset 0.

52. What are the different types of errors in PHP?

Here are three basic types of runtime errors in PHP:

1. Notices: These are trivial, non-critical errors that PHP encounters while executing a script - for example, accessing a variable that has not yet been defined. By default, such errors are not displayed to the user at all - although you can change this default behavior.

2. Warnings: These are more serious errors - for example, attempting to include() a file which does not exist. By default, these errors are displayed to the user, but they do not result in script termination.

3. Fatal errors: These are critical errors - for example, instantiating an object of a non-existent class, or calling a non-existent function. These errors cause the immediate termination of the script, and PHP's default behavior is to display them to the user when they take place.

53. What is SQL Injection?

SQL injection is a malicious code injection technique.It exploiting SQL vulnerabilities in Web applications

54. What is x+ mode in fopen() used for?

Read/Write. Creates a new file. Returns FALSE and an error if file already exists

55. How to find the position of the first occurrence of a substring in a string?

strpos() is used to find the position of the first occurrence of a substring in a string

56. What is PEAR?

PEAR is a framework and distribution system for reusable PHP components.The project seeks to provide a structured library of code, maintain a system for distributing code and for managing code packages, and promote a standard coding style.PEAR is broken into three classes: PEAR Core Components, PEAR Packages, and PECL Packages. The Core Components include the base classes of PEAR and PEAR_Error, along with database, HTTP, logging, and e-mailing functions. The PEAR Packages include functionality providing for authentication, networking, and file system features, as well as tools for working with XML and HTML templates.

57. Distinguish between urlencode and urldecode?

This method is best when encode a string to used in a query part of a url. it returns a string in which all non-alphanumeric characters except -_. have replece with a percentege(%) sign . the urldecode->Decodes url to encode string as any %and other symbole are decode by the use of the urldecode() function.

I will come up with more PHP interview questions and answers in second part of this post.