support: Customer Portal
Focused on delivering choice, investment protection and flexibility to organizations with valuable COBOL assets

Veryant Knowledge Base
Home > All Categories > isCOBOL General > What is the behavior difference of STOP THREAD?
Question Title What is the behavior difference of STOP THREAD?

I have heard that isCOBOL behaves differently on a STOP THREAD statement since a YIELD is needed. Please elaborate. 

What do you mean that a YIELD is needed? What exactly is the difference in behavior? What do I need to change in my program that uses STOP THREAD? How else can one thread stop another (e.g. change STOP THREAD to SEND and do a RECEIVE in the other threads)? What is the workaround?

Do you plan on fixing the above behavior to match ACUCOBOL-GT?


The main issue is that isCOBOL threads are real threads (java thread)and Java APIs don't allow running threads to be killed. (

Originally, STOP THREAD was not supported at all, and the only way to stop thread programatically was to change the COBOL code using messages. Since then, we have found a way to implement STOP THREAD. However, since isCOBOL uses the Java thread model, a call to the yield() method is required in order to allow thread interruption. For this reason we have added a new COBOL statement named YIELD to be used where the running thread must be stopped.

COBOL developers may need to control exactly where a running thread is stopped. STOP THREAD can be an unsafe statement to use because thread closing is not controlled. It is better practice to send a message closing the thread than to just to close the thread.

If you use STOP THREAD without also using YIELD statements, then the STOP THREAD would never return.

Programs using STOP THREAD should not execute a blocking ACCEPT, or other blocking statement, because this may cause the program to hang.

The solution is to use SEND to stop the thread, and then add ALLOWING MESSAGES FROM ANY THREAD to the ACCEPT statement. You could also have a timeout on ACCEPT or other statements, so the code can periodically call YIELD.
Authored by: Veryant Support This question has been viewed 6423 times so far.
Click Here to View all the questions in isCOBOL General category.
File Attachments File Attachments
There are no attachment file(s) related to this question.
How helpful was this article to you?
User Comments User Comments Add Comment
There are no user comments for this question. Be the first to post a comment. Click Here
Related Questions Related Questions
  1. How do I compile for compatibility with older versions of Java?
  2. When can I get the " Permission denied:connect" message? And how can it be avoided?
  3. How do I migrate indexed files to a format that is supported by isCOBOL?
  4. How do I resolve "code too large for try statement" errors?
  5. How do I prevent hackers from decompiling Java class files to reverse engineer my COBOL application?
  6. What Micro Focus library routines are supported?
  7. Do I need to worry about the compile warning "Note: uses unchecked or unsafe operations?"
  8. How can I read an Excel spreadsheet from COBOL?
  9. Does SET ADDRESS OF X TO Y work?
  10. How do I create a desktop shortcut icon to launch my program?
  11. What tools are available for automated functional (regression) testing of a COBOL application?
  12. Is there currently a way to debug COBOL and Java source together?
  13. Where can I obtain a copy of the ANSI 2002 COBOL standard?
  14. How do I set up isCOBOL to access Vision files?
  15. How do I increase the maximum Java heap size when compiling?
  16. How do I resolve a compile error on PIC X(2) USAGE COMP-5?
  17. How can I package my application and execute it in a JAR file?
  18. Should I use JISAM or isCOBOL ISAM Server (c-treeACE)?
  19. What is the best way to control Microsoft Word?
  20. How would I create my own CBL_ALLOC_MEM and CBL_FREE_MEM routines?
  21. How do I turn on debug trace to produce a log file?
  22. How can I use the F10 key in my application without it changing the keyboard focus?
  23. What is the recommended method for specifying isCOBOL framework properties?
  24. Where can I find more information on A$ENCRYPT and A$DECRYPT?
  25. Why do I get a compile error "--S: Invalid open mode" on an OPEN I-O of an ORGANIZATION LINE SEQUENTIAL file?
  26. Does isCOBOL work with Flexus COBOL sp2?
  27. How do I get my screens to be the same size and spacing as when I run with ACUCOBOL?
  28. How do I change the icon in the upper left corner of the Window?
  29. How do I use conditional compilation?
  30. How do I select 11x17 paper size using WIN$PRINTER?
  31. What are the defaults for the DATE-ENTRY control DISPLAY-FORMAT property and format styles?
  32. How do I specify properties or a properties file on the command line?
  33. How does a program detect at runtime whether it is running standalone GUI, thin client or with Web Direct 2.0?
  34. What are the key technical advantages of isCOBOL?
  35. How would I create my own CBL_CHECK_FILE_EXIST routine?
  36. Why do I get the error message "Native call not found" and how do I fix the problem?
  37. Sending SMTP mail
  38. Does isCOBOL run on Linux on System z?
  39. Can Veryant recommend a good Web site to find 3rd party JavaBeans?
  40. How do I compile fixed (ANSI) format source that COPYs terminal format source or vice versa?
  41. Where can I learn more about Classpath, the Java class loader, JDK tools and utilities?
  42. Why do I get the error java.lang.NoClassDefFoundError: com/iscobol/rts_n/StopRunException?
  43. What compile option should I use for ICOBOL compatibility?
  44. Is the isCOBOL 2009 SP1 release intended to deploy mainframe applications over the cloud? Or is it an integration mechanism for bringing in cloud data and apps?
  45. What algorithm does isCOBOL use to load framework properties (runtime config variables)?
  46. How can I make my isCOBOL program to be called instead of a C routine when both have the same name?
  47. Can isCOBOL access a DLL or .so that is in a JAR file?
  48. Is there any equivalent to COPY RESOURCE?
  49. Can I use directory paths in CALL names?
  50. How do I set iscobol.file.index.FileName with variable file name assignments?
  51. How do I specify which file status codes I want to use?
  52. How do I write my own replacement for a C$ library routine?
  53. How do I print to a spooler in Unix?
  54. What is the easiest and/or best way to convert a legacy text-based user interface to a web front end?
  55. Does isCOBOL APS run on z/OS?
  56. How do I configure file locations with environment variables?
  57. What should I use for USAGE HANDLE items instead of NULL?
  58. Is your runtime library backward compatible?
  59. Is isCOBOL backward compatible?
  60. How do I get more information when I get java.lang.reflect.InvocationTargetException?
  61. Can you derive isCOBOL object classes from Java and vice versa?
  62. How can I tell what changes were made in the isCOBOL latest update?
  63. Is there any way to use isCOBOL with SCO 5.0.6 (JDK 1.3)?
  64. I've heard there is a problem passing pointers to C functions. What is it?
  65. What is the best way to profile an isCOBOL program?
  66. Is there a way to have single set of source code that will compile with both ACUCOBOL and isCOBOL?
  67. Can the file system (iscobol.file.index) be set programmatically?
  68. Does isCOBOL support C$REDIRECT?
  69. Does isCOBOL support Crystal Reports or other Report Writers?
  70. How do I suppress multiple reserved words with the -rw compiler option?
  71. How do I determine what properties are set?
  72. Why do I get the error message “java.lang.UnsatisfiedLinkError: no ### in java.library.path?
  73. How can I monitor a jvm started on a remote computer box?
  74. How can I avoid the "java.lang.OutOfMemoryError: PermGen space" error?
  75. Why do I get the error message "java.lang.ArrayIndexOutOfBoundsException" ?
  76. What does mean the error NO X11 DISPLAY?
  77. How can I avoid, in execution, the "java.lang.OutOfMemoryError: Java heap space" error?
  78. Can I call an RMCobol program passing parameters to it?
  79. I still get the error : "Missing License: The license key is missing, invalid or has expired!" I can't figure out why
  80. Why do I get the error message "java.lang.NullPointerException" ?
  81. How do I resolve the error "java.lang.NoClassDefFoundError" or "java.lang.ClassNotFoundException"?
  82. Why do I get the error "Could not load the main class" ?
  83. Is there any way to direct the output from the “Print Screen” keyboard key directly to a printer?
  84. Did you know how to write custom information inside isCOBOL log file?
  85. Did you know that in a string you can replace a text with a new one with a different length by using the C$REPLACE_ALL routine?
  86. Did you know you could set properties to configure the PDF'S generation while printing?
  87. Did you know you can encrypt the communication with the isCOBOL Server?
  88. GIT Server (Linux) - Install and Configuration
Article Information Additional Information
Article Number: 44
Created: 2009-08-31 5:06 PM
Rating: 3 Stars
Article Options Article Options
Print Question Print this Question
Email Question Email Question to Friend
Export to Adobe PDF Export to PDF File
Export to MS Word Export to MS Word
Bookmark Article
Subscribe to Article Subscribe to Article
Search Knowledge Base Search Knowledge Base


© Veryant - All Rights Reserved
Veryant and isCOBOL are trademarks or registered marks of Veryant in the United States and other countries. All other marks are the property of their respective owners.