Software:ThreadSafe

From HandWiki
ThreadSafe
ThreadSafe for Eclipse screenshot.png
ThreadSafe for Eclipse
Developer(s)Contemplate
Stable release
1.3 / March 28, 2014; 10 years ago (2014-03-28)
Operating systemCross-platform: Linux, OS X, Windows
TypeStatic code analysis
LicenseProprietary software
Websitewww.contemplateltd.com/threadsafe

ThreadSafe is a source code analysis tool that identifies application risks and security vulnerabilities associated with concurrency in Java code bases, using whole-program interprocedural analysis.[1][2][3][4] ThreadSafe is used to identify and avoid software failures in concurrent applications running in complex environments.[1][2][5][6]

Features

ThreadSafe detects Java concurrency defects:[2][3][4]

  • Race conditions – which lead to incorrect or unpredictable behaviour that is difficult to reproduce in a debugger.
  • Deadlocks[7] – caused by circular waits between threads waiting for shared resources.
  • Unpredictable results – caused by incorrect handling of concurrent collections, bad error handling, or mixed object synchronization.
  • Performance bottlenecks – caused by incorrect API usage, redundant synchronization, and unnecessary use of shared mutable state.

ThreadSafe is integrated with the Eclipse software development environment and with the SonarQube software quality management platform. Contextual information is provided within the development environment to assist the developer with the investigation and resolution of concurrency issues, directly in the code.[2][3][4] A command-line version is available for users of IDEs other than Eclipse and for build process integration.

Checking adherence to standards

ThreadSafe detects violations of the concurrency-related rules in the CERT Oracle Secure Coding Standard for Java.[8]

See also

References

  1. 1.0 1.1 Grazi, Victor (August 28, 2013). "ThreadSafe Concurrency Static Analysis Tool Announces First Public Release". InfoQ.com. http://www.infoq.com/news/2013/08/ThreadSafe-Public-Release. 
  2. 2.0 2.1 2.2 2.3 Taft, Darryl (September 4, 2013). "Contemplate Delivers ThreadSafe Java Concurrency Static Analysis Tool". DevX.com. http://www.devx.com/Java/contemplate-delivers-threadsafe-java-concurrency-static-analysis-tool.html. 
  3. 3.0 3.1 3.2 Atkey, Robert (January 14, 2014). "Discover and Diagnose Java Concurrency Problems Using Contemplate's ThreadSafe". InfoQ.com. http://www.infoq.com/articles/Java-Concurrency-Static-Analysis-with-ThreadSafe. 
  4. 4.0 4.1 4.2 Atkey, Robert; Sannella, Donald (2015). "ThreadSafe: Static Analysis for Java Concurrency". Electronic Communications of the EASST 72. doi:10.14279/tuj.eceasst.72.1025.995. 
  5. Roy, Ritobaan (May 1, 2013). "Software Errors: New Technology Briefing For CFOs". CFO Insight. Archived from the original on October 14, 2013. https://web.archive.org/web/20131014022454/http://www.cfo-insight.com/risk-management-it/it/software-errors-new-technology-briefing-for-cfos/. 
  6. Rubens, Paul (March 12, 2014). "Why Software Testing Can't Save You From IT Disasters". CIO.com. http://www.cio.com/article/749493/Why_Software_Testing_Can_t_Save_You_From_IT_Disasters. 
  7. Raible, Matt (June 26, 2014). "Contemplate ThreadSafe Introduces Deadlock Detection". InfoQ.com. http://www.infoq.com/news/2014/06/threadsafe-deadlock-detection. 
  8. "SEI CERT Oracle Coding Standard for Java". Software Engineering Institute, Carnegie Mellon University. http://www.securecoding.cert.org/confluence/display/java/SEI+CERT+Oracle+Coding+Standard+for+Java. Retrieved March 18, 2016. 

External links