[zeromq-dev] Extending zmq_msg_t API
Goswin von Brederlow
goswin-v-b at web.de
Wed Jul 9 11:21:58 CEST 2014
On Tue, Jul 08, 2014 at 10:42:41AM -0500, Thomas Rodgers wrote:
> tl;dr; Is there any objection to adding some sort of accessor to the API to
> determine if a given zmq_msg_t is_shared()?
>
> Background/Rationale:
>
> Something I encountered while writing a "high level" C++ wrapper for
> zmq_msg_t and it's API is the following set of behaviors -
>
> zmq_msg_init(&msg_vsm, 20);
>
> Results in a type_vsm message, the body of which is held entirely within
> the space allocated to zmq_msg_t
>
> zmq_msg_init(&msg_lmsg, 1024);
>
> Results in a type_lmsg message, the body is held as a reference to a block
> of size bytes.
>
> memcpy(zmq_msg_data(&msg_vsm), "VSM", 3);
> memcpy(zmq_msg_data(&msg_lmsg), "LMSG", 4);
>
> So far so good. Now copy -
>
> zmq_msg_copy(&msg_vsm2, &msg_vsm);
> zmq_msg_copy(&msg_lmsg2, &msg_lmsg);
>
> Now change contents -
>
> memcpy(zmq_msg_data(&msg_vsm2), "vsm", 3);
> memcpy(zmq_msg_data(&msg_lmsg2), "lmsg", 4);
>
> assert(memcmp(&msg_vsm, &msg_vsm2, 3) != 0); // ok
> assert(memcmp(&msg_lmsg, &msg_lmsg2, 4) != 0); // fail
>
> This happens by design (lmsg's are refcounted on copy, not deep copied).
> But it results in a situation where a zmq_msg_t is sometimes a Value and
> sometimes a Reference. This could lead to astonishment for the unwary.
>
> >From the perspective of a wrapper (particularly one that takes a strong
> stand on value semantics and local reasoning), this behavior is ungood. So
> my options are deep copy always or implement copy-on-write.
>
> For efficiency I prefer the latter approach in the case of type_lmsg
> messages. I have implemented the copy-on-write logic through a horrible
> brittle hack that examines the last byte of zmq_msg_t. I would prefer a
> less brittle solution.
"lmsg's are refcounted on copy" Can't you access the refcount?
Or is that the API call you want to add?
Maybe instead of is_shared() an unshare() call would be more usefull,
which would copy the message payload if it is shared. Or both?
MfG
Goswin
More information about the zeromq-dev
mailing list