名前空間
変種
操作

std::memmove

From cppreference.com
< cpp‎ | string‎ | byte
 
 
 
 
ヘッダー <cstring> で定義
void* memmove( void* dest, const void* src, std::size_t count );

以下の操作を順番に実行します

  1. 暗黙的にオブジェクトを生成します dest に。
  2. src が指すオブジェクトから、count バイトを、count バイトの一時配列 arr にコピーします。arrdest が指すオブジェクトと src が指すオブジェクトと重複しません。count バイトは unsigned char 型として扱われます(以下同様)。
  3. arr から count バイトを dest が指すオブジェクトにコピーします。

dest または srcヌルポインタまたは無効なポインタの場合、振る舞いは未定義です。

目次

[編集] パラメータ

dest - コピー先のメモリ位置へのポインタ
src - コピー元のメモリ位置へのポインタ
count - count

[編集] 戻り値

適切な生成されたオブジェクトが存在する場合、そのポインタを返します。それ以外の場合は dest を返します。

[編集] 注記

仕様では一時バッファが使用されるとされていますが、この関数の実際の С++ 実装は二重コピーや追加メモリのオーバーヘッドを発生させません。小さな count の場合、レジスタにロードして書き出すことがあります。大きなブロックの場合、一般的なアプローチ(glibcやbsd libc)は、宛先がソースの前に始まる場合はバッファの先頭から前方にバイトをコピーし、そうでなければ末尾から後方にコピーします。重複が全くない場合は std::memcpy にフォールバックします。

厳密エイリアシングが異なる型の値として同じメモリを検査することを禁止している場合、`std::memmove` を使用して値を変換することができます。

[編集]

#include <cstring>
#include <iostream>
 
int main()
{
    char str[] = "1234567890";
    std::cout << str << '\n';
    std::memmove(str + 4, str + 3, 3); // copies from [4, 5, 6] to [5, 6, 7]
    std::cout << str << '\n';
}

出力

1234567890
1234456890

[編集] 不具合報告

以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。

DR 適用対象 公開された動作 正しい動作
LWG 4064 C++98 返されるポインタが適切な生成されたオブジェクトを指すかどうか不明確でした。 明確化された

[編集] 関連項目

あるバッファを別のバッファにコピーする
(関数) [編集]
バッファを文字で埋める
(関数) [編集]
オーバーラップしている可能性のある2つの配列間で、指定された数のワイド文字をコピーする
(関数) [編集]
要素の範囲を新しい場所にコピーする
(関数テンプレート) [編集]
要素の範囲を逆順にコピーする
(関数テンプレート) [編集]
型がトリビアルにコピー可能であるかをチェックする
(クラステンプレート) [編集]
English 日本語 中文(简体) 中文(繁體)