R.1 example: change names according to NL.8

This commit is contained in:
Thibault Kruse 2016-08-18 02:00:36 +02:00
parent 0af83def79
commit be304fedd6

View File

@ -7588,17 +7588,17 @@ Consider:
void send(X* x, cstring_span destination) void send(X* x, cstring_span destination)
{ {
auto port = OpenPort(destination); auto port = open_port(destination);
my_mutex.lock(); my_mutex.lock();
// ... // ...
Send(port, x); send(port, x);
// ... // ...
my_mutex.unlock(); my_mutex.unlock();
ClosePort(port); close_port(port);
delete x; delete x;
} }
In this code, you have to remember to `unlock`, `ClosePort`, and `delete` on all paths, and do each exactly once. In this code, you have to remember to `unlock`, `close_port`, and `delete` on all paths, and do each exactly once.
Further, if any of the code marked `...` throws an exception, then `x` is leaked and `my_mutex` remains locked. Further, if any of the code marked `...` throws an exception, then `x` is leaked and `my_mutex` remains locked.
##### Example ##### Example
@ -7610,7 +7610,7 @@ Consider:
Port port{destination}; // port owns the PortHandle Port port{destination}; // port owns the PortHandle
lock_guard<mutex> guard{my_mutex}; // guard owns the lock lock_guard<mutex> guard{my_mutex}; // guard owns the lock
// ... // ...
Send(port, x); send(port, x);
// ... // ...
} // automatically unlocks my_mutex and deletes the pointer in x } // automatically unlocks my_mutex and deletes the pointer in x
@ -7621,8 +7621,8 @@ What is `Port`? A handy wrapper that encapsulates the resource:
class Port { class Port {
PortHandle port; PortHandle port;
public: public:
Port(cstring_span destination) : port{OpenPort(destination)} { } Port(cstring_span destination) : port{open_port(destination)} { }
~Port() { ClosePort(port); } ~Port() { close_port(port); }
operator PortHandle() { return port; } operator PortHandle() { return port; }
// port handles can't usually be cloned, so disable copying and assignment if necessary // port handles can't usually be cloned, so disable copying and assignment if necessary