Posted on 2006-11-29 19:31
平凡的天才 閱讀(1528)
評論(9) 編輯 收藏 引用
在C/C++語言中,將一個組合數(shù)據(jù)類型如結(jié)構(gòu)各個字段的值復(fù)制到另一個相同類型的結(jié)構(gòu)中,可以將其對應(yīng)字段賦值。這種方法對于各種復(fù)雜的結(jié)構(gòu)如多字段結(jié)構(gòu)、嵌套結(jié)構(gòu),就要寫很多行賦值語句,而且如果原來的結(jié)構(gòu)定義更改,程序代碼就要隨著更改,使用很不方便。本文給出了一個通用的結(jié)構(gòu)復(fù)制函數(shù)。
????????假定結(jié)構(gòu)的類型為STRUCT_TYPE。為了提高效率,用指針引入兩個結(jié)構(gòu)到函數(shù)中;為了通用,這兩個指針用任意指針。函數(shù)設(shè)計(jì)的出發(fā)點(diǎn)是,每個結(jié)構(gòu)在內(nèi)存中各字段連續(xù)存放,而且,每個字段可以分解中一個一個的字節(jié)。這樣,復(fù)制結(jié)構(gòu)時,可以讓兩個結(jié)構(gòu)的對應(yīng)的每個字節(jié)表示的值相等。于是,函數(shù)設(shè)計(jì)如下:
??void?struct_copy(
????void?*p_struct1,???/*結(jié)構(gòu)指針1*/
????void?*p_struct2,???/*結(jié)構(gòu)指針2*/
????unsigned?int?struct_size???/*結(jié)構(gòu)類型長度,可以用sizeof(STRUCT_TYPE)代入*/
?????)
????{
?int?count=0;
?char?*p_char1,*p_char2;
?
?p_char1=(char?*)p_struct1;
?p_char2=(char?*)p_struct2;
?
?while(count!=struct_size)
?{
??*p_char1=*p_char2;
??p_char1++;
??p_char2++;
??count++;
?}
????}
這個函數(shù)在PC機(jī)和康柏ALPHA小型機(jī)上使用效果不錯。
????????有了這個函數(shù),如有類型同為STRUCT_TYPE的兩個結(jié)構(gòu)struct1和struct2,要使struct1各字段的值與struct2各字段的值相等,也就是要把struct2各字段的值賦給struct1,就可以這樣調(diào)用以上函數(shù):?struct_copy(&struct1,?&struct2,?sizeof(STRUCT_TYPE));??????
????????以上函數(shù)簡單、通用、有效,對任意結(jié)構(gòu)類型有效,也適合于其它復(fù)雜數(shù)據(jù)類型,如聯(lián)合(union)等。有趣的是,它也適合與整形、浮點(diǎn)型等簡單數(shù)據(jù)類型的變量之間復(fù)制。
????????此函數(shù)的設(shè)計(jì)思想可以運(yùn)用在很多方面,如進(jìn)程之間、計(jì)算機(jī)之間通信時,可以在通信的一方將某些數(shù)據(jù)類型拆分成字節(jié),到達(dá)通信的另一方再將收到的字節(jié)拼成相應(yīng)的數(shù)據(jù)類型,這比按位傳遞要簡單、高效得多。
Feedback
# re: 通用的復(fù)合數(shù)據(jù)類型的賦值函數(shù) 回復(fù) 更多評論
2006-11-29 23:34 by
博主貎似在寫memcpy()函數(shù)的具體實(shí)現(xiàn)……
# re: 通用的復(fù)合數(shù)據(jù)類型的賦值函數(shù) 回復(fù) 更多評論
2006-11-30 00:32 by
有必要這樣嗎, memcpy就解決了.
# re: 通用的復(fù)合數(shù)據(jù)類型的賦值函數(shù) 回復(fù) 更多評論
2006-11-30 08:29 by
樓主似乎沒用過memcpy(...);哈哈,猜測
# re: 通用的復(fù)合數(shù)據(jù)類型的賦值函數(shù) 回復(fù) 更多評論
2006-11-30 08:31 by
如果你沒用過memcpy(...),而自己悟出需要個這樣的函數(shù),
就有點(diǎn)NB了。
# re: 通用的復(fù)合數(shù)據(jù)類型的賦值函數(shù) 回復(fù) 更多評論
2006-11-30 16:32 by
C++ 的對象默認(rèn)的賦值操作就是如此, 何必再寫函數(shù)。比如:
struct foo
{
int a;
char b;
};
void main()
{
foo f, g;
f.a=f.b=0;
g = f;
}
# re: 通用的復(fù)合數(shù)據(jù)類型的賦值函數(shù) 回復(fù) 更多評論
2006-12-01 07:10 by
這樣的函數(shù)似乎只能表層復(fù)制,如果對象含有指針成員好像會出錯啊
# re: 通用的復(fù)合數(shù)據(jù)類型的賦值函數(shù) 回復(fù) 更多評論
2006-12-02 23:14 by
做你有把握的事!
# re: 通用的復(fù)合數(shù)據(jù)類型的賦值函數(shù) 回復(fù) 更多評論
2006-12-10 15:32 by
我測試過,如果內(nèi)含指針一樣可以使用,但是必須保證存儲空間是連續(xù)的!
# re: 通用的復(fù)合數(shù)據(jù)類型的賦值函數(shù) 回復(fù) 更多評論
2006-12-13 10:05 by
暈死!竟然是一個字節(jié)一個字節(jié)的拷貝.