Re: file reader returning null when file is not null content
jason wrote:
i [sic] am using the java [sic] desktop application developer in NetBeans.
When I use the following program:
[CODE]
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package readtextfileexample;
/**
*
* @author amandaabdou
*/
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.FileNotFoundException;
import java.io.IOException;
public class Main {
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
String A;
A=FileReader("/Users/"+System.getProperty("user.name")+"/
You should follow the naming conventions.
Desktop/ad_log.txt");
System.out.println(A);
}
public static String FileReader(String args){
File file = new File(args);
StringBuffer contents = new StringBuffer();
BufferedReader reader = null;
String For_Output="";
try
{
reader = new BufferedReader(new FileReader(file));
String text = null;
// repeat until all lines is read
while ((text = reader.readLine()) != null)
{
contents.append(text)
.append(System.getProperty(
"line.separator"));
For_Output+=text;
}
} catch (FileNotFoundException e)
{
e.printStackTrace();
} catch (IOException e)
{
e.printStackTrace();
} finally
{
try
{
if (reader != null)
{
reader.close();
}
} catch (IOException e)
{
e.printStackTrace();
}
}
// show file contents here
return For_Output;
}
}
[/CODE]
in a java [sic] application in netbeans [sic], it runs perfectly and does exactly
what i [sic] want.
Case matters in Java. It's good practice to use correct case in writing about
Java matters.
if i [sic] attempt to migrate the method of FileReader to my basic desktop
application it no longer works.
this desktop application is using the exact same library imports and
is using identical code aside from one aspect. my FileReader method is
now called:
[CODE]
private String FileReader(String args)
[/CODE]
And that didn't give you a compiler error?
There is a significant difference between static and instance methods. But
since we don't get the whole picture, we can't tell exactly why you didn't get
a compiler error when the method changed from static to instance.
Either way, the method name should be spelled with an initial lower-case
letter, as with variables.
<http://java.sun.com/docs/codeconv/index.html>
I also suspect that markspace is onto something with hi comments about the
"java [sic] desktop application developer".
--
Lew