Submitter: Blaine Garst
Submission Date: 2013年07月31日
Summary
It has been noted that the descriptions for 7.24.2.1memcpy, 7.24.2.2 memmove and 7.24.4.1 memcmp are written using the term character which is inconsistent with their design as memory functions. Moreover, if one then reads 3.7.2 as allowing character to mean multibyte character, it is thought that confusion could arise as to whether the number of multibyte characters should be supplied rather than the number of bytes.
Although it is clear by 7.24.1 String function conventions paragraph 3
For all functions in this sub clause, each character shall be interpreted as if it had the type unsigned char
that the number of bytes to be used corresponds to the size of a unsigned char, one has to reference 6.2.6 Representation of types to learn that unsigned char is in fact a single byte (consisting of CHAR_BIT bits).
It would be simpler and more to the point if the three memory functions describe their count parameter n in terms of bytes.
Suggested Technical Corrigendum
memcpy
Change 7.24.2.1 p 2 first sentence from
Thememcpyfunction copiesn(追記) characters (追記ここまで) from the object pointed to bys2into the object pointed to bys1.
to
Thememcpyfunction copiesn(追記) bytes (追記ここまで) from the object pointed to bys2into the object pointed to bys1.
memmove
Change 7.24.2.2 p 2 from
Thememmovefunction copiesn(追記) characters (追記ここまで) from the object pointed to bys2into the object pointed to bys1. Copying takes place as if then(追記) characters (追記ここまで) from the object pointed to bys2are first copied into a temporary array ofn(追記) characters (追記ここまで) that does not overlap the objects pointed to bys1ands2, and then then(追記) characters (追記ここまで) from the temporary array are copied into the object pointed to bys1.
to
Thememmovefunction copiesn(追記) bytes (追記ここまで) from the object pointed to bys2into the object pointed to bys1. Copying takes place as if then(追記) bytes (追記ここまで) from the object pointed to bys2are first copied into a temporary array ofn(追記) bytes (追記ここまで) that does not overlap the objects pointed to bys1ands2, and then then(追記) bytes (追記ここまで) from the temporary array are copied into the object pointed to bys1.
memcmp
Change 7.24.4.1 p 2 from
Thememcmpfunction compares the firstn(追記) characters (追記ここまで) of the object pointed to bys1to the firstn(追記) characters (追記ここまで) of the object pointed to bys2.
to
Thememcmpfunction compares the firstn(追記) bytes (追記ここまで) of the object pointed to bys1to the firstn(追記) bytes (追記ここまで) of the object pointed to bys2.