Skip to main content

What is the difference between getPath() and getAbsolutePath() and getCanonicalPath() methods?

File is one of the most deceiving classes in the API. It does not represent a file, it does not represent a directory. Remember that creating a File object does not imply you have got a corresponding file or directory in the file system.

A File object represents an abstract path name for a file or directory that may exist (or not) in the file system. Read the API for more details on that. Let's take a look these API:
  • public String getPath() returns the name of the File object including the path name, whether relative or absolute.
  • public String getAbsolutePath() returns the absolute path name of the File object. If the file contains a relative path name, it figures out what the absolute path name would be and returns it. No IOException is thrown if the path name is impossible under the file system naming convention.
  • public String getCanonicalPath() returns an absolute and unique pathname of the File object. An IOException is thrown if the path name is not possible. The precise definition of canonical form is system-dependent, but canonical forms are always absolute.
A canonical pathname is both absolute and unique. The precise definition of canonical form is system-dependent. This method first converts this pathname to absolute form if necessary, as if by invoking the getAbsolutePath() method, and then maps it to its unique form in a system-dependent way. This typically involves removing redundant names such as "." and ".." from the pathname, resolving symbolic links (on UNIX platforms), and converting drive letters to a standard case (on Microsoft Windows platforms).

Every pathname that denotes an existing file or directory has a unique canonical form. Every pathname that denotes a nonexistent file or directory also has a unique canonical form. The canonical form of the pathname of a nonexistent file or directory may be different from the canonical form of the same pathname after the file or directory is created. Similarly, the canonical form of the pathname of an existing file or directory may be different from the canonical form of the same pathname after the file or directory is deleted.

The characters used for separating directory and file names in a path name are different across different operating systems. The File class provides character constants for the separator character-that is, the character between directory and file names-and also the path separator, which is the character between path names in a path list like the CLASSPATH. The separatorChar variable contains the character that separates file and directory names in a path:
 
public final static char separatorChar

This character is a / under UNIX, but a \ under Windows NT and Windows 95. The pathSeparatorChar contains the character that separates path names in a path list:
 
public final static char pathSeparatorChar
This character is ; under Windows NT/95 and : under UNIX.

Click below links to know more

Comments

Popular posts from this blog

WebSphere MQ Interview Questions

What is MQ and what does it do? Ans. MQ stands for MESSAGE QUEUEING. WebSphere MQ allows application programs to use message queuing to participate in message-driven processing. Application programs can communicate across different platforms by using the appropriate message queuing software products. What is Message driven process? Ans . When messages arrive on a queue, they can automatically start an application using triggering. If necessary, the applications can be stopped when the message (or messages) have been processed. What are advantages of the MQ? Ans. 1. Integration. 2. Asynchrony 3. Assured Delivery 4. Scalability. How does it support the Integration? Ans. Because the MQ is independent of the Operating System you use i.e. it may be Windows, Solaris,AIX.It is independent of the protocol (i.e. TCP/IP, LU6.2, SNA, NetBIOS, UDP).It is not required that both the sender and receiver should be running on the same platform What is Asynchrony? Ans. With messag...

Asynchronous Vs. Synchronous Communications

Synchronous (One thread):   1 thread -> |<---A---->||<----B---------->||<------C----->| Synchronous (multi-threaded):   thread A -> |<---A---->| \ thread B ------------> ->|<----B---------->| \ thread C ----------------------------------> ->|<------C----->|

Advantages & Disadvantages of Synchronous / Asynchronous Communications?

  Asynchronous Communication Advantages: Requests need not be targeted to specific server. Service need not be available when request is made. No blocking, so resources could be freed.  Could use connectionless protocol Disadvantages: Response times are unpredictable. Error handling usually more complex.  Usually requires connection-oriented protocol.  Harder to design apps Synchronous Communication Advantages: Easy to program Outcome is known immediately  Error recovery easier (usually)  Better real-time response (usually) Disadvantages: Service must be up and ready. Requestor blocks, held resources are “tied up”.  Usually requires connection-oriented protocol