CTRL-C While a process is getting executed marks it as changed

Posted on 1998-07-07
Medium Priority
Last Modified: 2010-03-30
Env:- windows

I am calling
ftp -n -s:filename
from within the java program
( exec( "ftp -n -s:somefile.tar.gz ") )
now the problem is while the ftp is in progress
if the user presses ctrl-c windows will come out of the program
but it will mark the file (been ftp'd) as been modified and wont allow me to delete
the file till garbage collector runs how to overcome this problem.
Question by:gopalindia
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
  • 3
  • 2

Accepted Solution

aziz061097 earned 100 total points
ID: 1225293
If you want to force a garbage collection you can call the method System.gc() . If your question is different from just getting the Garbage collector started , please give more details. How are you calling the ftp command (is it programmatically using ftp client or by invoking the shell ftp command ?

Author Comment

ID: 1225294
c:\java programname
--ftp in progress.
--ctrl -c
c:\ prompt.

I am calling the dos shell.
CTRL-C is an higher level interrupt which I cannot trap inside the java application and therefore i cannot call system.gc() as it will cause it to come out of the shell because of which i cannot delete the file or rename it or call my ftp program again until the garbage collector has collected the process and released the file.


Expert Comment

ID: 1225295
Pressing Ctrl-C kills the Java program or only kills the FTP process it started?
Get real performance insights from real users

Key features:
- Total Pages Views and Load times
- Top Pages Viewed and Load Times
- Real Time Site Page Build Performance
- Users’ Browser and Platform Performance
- Geographic User Breakdown
- And more


Author Comment

ID: 1225296
It kills the java program and ftp process.
But leaves a flag in the windows OS saying that the file is been modified and no other user should modify it and the result is you cannot move or rename or do anything with the file for say about half an hour or so depending upon when windows will reset the flag for the file and all subsequent operations to ftp the file will fail as you dont have write permissions to the file.

Expert Comment

ID: 1225297
Sounds like you need to do some cleanup in your code. First of all, you can call process.waitFor(), after you exeute exec() method. The former method blocks the thread until the process you started is finished. There you can clean up after the process (close all files, streams etc). Even more foolproof techinqueis to have a finalize method where you do similar cleanup. Garbage collector calls it before the program exits. (Since your java program gets killed, I do not think the problem is in the GC timing. I think you simply fail to release the resources in your program).  And yet another mechanism is to put a try/catch/finally block in your code where finally block will do the cleanup no matter what happens inside the try or catch blocks.

Author Comment

ID: 1225298
Dear friend Thanx for responding I am aware of
finally part
The thing is CTRL-C will not be caught in try catch.
here is my program.
  r_ftp = Runtime.getRuntime();
      String s_ftp_ex = new String( "ftp -n -s:"+s_cnl_tmp_txt );
      p_ftp=r_ftp.exec ( s_ftp_ex );
    catch (IOException e)
      System.out.println("IOException "+e );
    catch (InterruptedException e)
      System.out.println("Interrupted "+e );
    catch ( Exception e )
      System.out.println("Something wrong"+e );

Now the thing is it is a big file which is to be ftp'd and it waits till the ftp is over
and if you press ctrl-c in between you cannot modify the file nor try to do ftp again till it is reset by windows flag.


Expert Comment

ID: 1225299
Hi Gopal,

        You can atleast call System.gc() in the finally clause .


Expert Comment

ID: 1225300
What do you mean by "reset by window flag". What exactly happens to the file you are trying to FTP when you press Ctrl-C? What happens if you simply start run FTP command from the command line (outside of Java program) and try Ctrl-C? Will teh same thing happen? (If so, Java have nothing to do with it, it is the way "ftp" is implemented).

Author Comment

ID: 1225301
Thank you guys for replying to my question:-
Aziz:- I cant call system.gc() because it is not trapped by the java Exception at all and no way I can call system.gc.

msmolyak:-Had ftp been the problem then why I can do the same thing within  perl and not with java.

When i try ftp from other programs everything goes fine and moreover I have found the answer it is Java has got a package
sun.net which i am using...
Thank you guys.

Thank you


Featured Post


Modern healthcare requires a modern cloud. View this brief video to understand how the Concerto Cloud for Healthcare can help your organization.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This was posted to the Netbeans forum a Feb, 2010 and I also sent it to Verisign. Who didn't help much in my struggles to get my application signed. ------------------------- Start The idea here is to target your cell phones with the correct…
Introduction This article is the first of three articles that explain why and how the Experts Exchange QA Team does test automation for our web site. This article explains our test automation goals. Then rationale is given for the tools we use to a…
Viewers will learn one way to get user input in Java. Introduce the Scanner object: Declare the variable that stores the user input: An example prompting the user for input: Methods you need to invoke in order to properly get  user input:
The viewer will learn how to implement Singleton Design Pattern in Java.
Suggested Courses
Course of the Month14 days, 5 hours left to enroll

801 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question