Jump to content

Recommended Posts

Posted (edited)

If you want to write a formal specification of a program written in C++ or Java, then how can you know the logic of the C++ program you've written?

 

I searched the Internet for books which rigorously teach the subjects of semantics of programming languages and formal specification and I couldn't find any and the three I did find are not rigorous and are quite out of date.


Merged post follows:

Consecutive posts merged

I'll phrase my question differently.

 

Let's say I wrote a program in C++. How do I create a formal specification of the program I've written?

 

Two popular specification languages are the Z notation and VDM (Vienna Development Method). So if I wrote my program in C++, does it mean I have to translate the C++ program to Z notation or VDM? But how do I do that?

 

Do I need to know the semantics of C++ in order to do this? I searched the net for books which teach the semantics of C++ but couldn't find any.

Edited by Uri
Consecutive posts merged.
Posted

Formal spec can mean a lot of things.

 

It almost sounds like you want a C++ model checker:

 

http://www.cprover.org/cbmc/

 

Aside from that, you cannot formally specify C++ programs, because C++ is a quasi-superset of C, and C has "dangerous" semantics.

 

Perhaps if your program used a subset of C++ which involved no pointers and used references exclusively you could formally specify it.

 

Is this for a class?

Posted
Formal spec can mean a lot of things.

 

It almost sounds like you want a C++ model checker:

 

http://www.cprover.org/cbmc/

 

Aside from that, you cannot formally specify C++ programs, because C++ is a quasi-superset of C, and C has "dangerous" semantics.

 

But what is a quasi-superset and what is dangerous semantics?

 

Is this for a class?

 

No it's not for a class. It's just something I'm interested knowing.

Posted

C++ is not a proper superset of C (in the way Objective C is, for example).

 

There are valid C programs which are not valid C++. For example, in C, you can typedef a struct and give both the same name. This isn't valid C++, since in C++ a struct is just a class with everything public by default.

 

The dangerous semantics of C involve pointers. C has an inherently unsafe memory model. Subtle errors, buffer overruns, miscalculated pointer arithmetic, etc can corrupt your program's memory and lead to nondeterministic behavior.

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.