- 論壇徽章:
- 0
|
RPC的xdr(外部數(shù)據(jù)表示)是為了編碼(解碼)C語(yǔ)言定義的數(shù)據(jù),從而使得RPC傳輸?shù)臄?shù)據(jù)平臺(tái)無(wú)關(guān)性。
xdr對(duì)C語(yǔ)言常見(jiàn)的類(lèi)型編碼規(guī)則在之前已經(jīng)說(shuō)過(guò)了,參見(jiàn)
http://blog.chinaunix.net/u2/87570/showart_2159266.html
,對(duì)于說(shuō)明書(shū)test.x定義的定義,最終會(huì)被rpcgen翻譯成支持C語(yǔ)言支持的類(lèi)型定義,之后test.x就沒(méi)有任何作用了。
如在test.x中定義
struct data
{
char char_arg;
short short_arg;
long long_arg;
string vstring_arg;
opaque fopaque_arg[3];
char fchar_arg[3];
opoque vopaque_arg;
long vlong_arg;
};
對(duì)應(yīng)的test.h
struct data {
char char_arg;
short short_arg;
long long_arg;
char *vstring_arg;
char fopaque_arg[3];
char fchar_arg[3];
struct {
u_int vopaque_arg_len;
opoque *vopaque_arg_val;
} vopaque_arg;
struct {
u_int vlong_arg_len;
long *vlong_arg_val;
} vlong_arg;
};
typedef struct data data;
從test.h中可以看到,對(duì)于opaque[], char[]的定義,在C語(yǔ)言中對(duì)對(duì)應(yīng)char[],而根據(jù)xdr的規(guī)則,opaque[]編碼為固定長(zhǎng)度n個(gè)字節(jié)的序列(會(huì)被補(bǔ)全至4字節(jié)的倍數(shù));而char[]會(huì)被編碼成固定長(zhǎng)度n個(gè)4字節(jié)元素序列。怎么這里都是char[]???
別急,編碼規(guī)則在頭文件中是沒(méi)有顯現(xiàn)出來(lái)的,根據(jù)說(shuō)明書(shū)中定義,rpcgen會(huì)生成相應(yīng)的方法對(duì)各種數(shù)據(jù)進(jìn)行編碼,而這些編碼方法均在test_xdr.c中。
再看test_xdr.c
bool_t
xdr_data (XDR *xdrs, data *objp)
{
//xdr_char轉(zhuǎn)換char型數(shù)據(jù)類(lèi)型到其外部數(shù)據(jù)表示,每個(gè)char占4個(gè)字節(jié),unsigned char,short, unsigned short, int, unsigned int的編碼格式均相同
if (!xdr_char (xdrs, &objp->char_arg))
return FALSE;
if (!xdr_short (xdrs, &objp->short_arg))
return FALSE;
if (!xdr_long (xdrs, &objp->long_arg))
return FALSE;
//字符串類(lèi)型,序列前包含字符串的長(zhǎng)度,總長(zhǎng)度補(bǔ)全至4的倍數(shù)
if (!xdr_string (xdrs, &objp->vstring_arg, 128))
return FALSE;
//xdr_opaque用以轉(zhuǎn)換固定長(zhǎng)度不透明序列
if (!xdr_opaque (xdrs, objp->fopaque_arg, 3))
return FALSE;
//xdr_vector用以轉(zhuǎn)換固定長(zhǎng)度透明數(shù)據(jù)類(lèi)型序列
if (!xdr_vector (xdrs, (char *)objp->fchar_arg, 3,
sizeof (char), (xdrproc_t) xdr_char))
return FALSE;
//xdr_array用于轉(zhuǎn)換不定長(zhǎng)度的序列
if (!xdr_array (xdrs, (char **)&objp->vopaque_arg.vopaque_arg_val, (u_int *) &objp->vopaque_arg.vopaque_arg_len, ~0,
sizeof (opoque), (xdrproc_t) xdr_opoque))
return FALSE;
if (!xdr_array (xdrs, (char **)&objp->vlong_arg.vlong_arg_val, (u_int *) &objp->vlong_arg.vlong_arg_len, ~0,
sizeof (long), (xdrproc_t) xdr_long))
return FALSE;
return TRUE;
}
從test_xdr.c中可以看出,opaque[],char[]是分別是通過(guò)xdr_opaque,xdr_vector編碼(需要傳遞各個(gè)元素編碼的方法,如此例中的xdr_char()),故在xdr表示中opaque[],char[]是不同的。
對(duì)于opaque, datatype都是通過(guò)xdr_array實(shí)現(xiàn)的,同樣根據(jù)傳遞過(guò)來(lái)的編碼方法xdr_opaque, xdr_long,它們被編碼成不同的格式。
本文來(lái)自ChinaUnix博客,如果查看原文請(qǐng)點(diǎn):http://blog.chinaunix.net/u2/87570/showart_2163206.html |
|