Portál AbcLinuxu, 13. července 2025 19:32
float x;
unsigned short int y[10];
y[5]=//první půlka x;
y[6]=//druhá půlka x;
a pak zase spojit y[5] a y[6] do x.
#include <stdio.h>
#include <math.h>
#include <string.h>
int main()
{
float x;
unsigned short int y[10];
int i;
memset(y, 0, sizeof(unsigned short int)*10);
x = M_PI;
printf("pred x = %f\n", x);
memcpy(y+5, &x, sizeof(x));
//y[5]=//první půlka x;
//y[6]=//druhá půlka x;
x = 0.0;
memcpy(&x, y+5, sizeof(x));
//y[5]=//první půlka x;
//y[6]=//druhá půlka x;
printf("po x = %f\n", x);
return 0;
}
union
- viz příklad.
y[5] = x & 0xffff; y[6] = x >> 16; x = (y[6] << 16) | y[5];
Elegance C-ka :)
y[5] = * (unsigned short int *) &x; y[6] = * ((unsigned short int *) &x + 1); ... * (unsigned short int *) &x = y[5]; * ((unsigned short int *) &x + 1) = y[6];Nebo tak:
* (float *) &y[5] = x; ... x = * (float *) &y[5];
v c je taky dostupna union. Takze:
typedef union {
float fCislo;
uint16 au16Cisla[2];
} CisloVLoterii;
...
CisloVLoterii *pCislo;
...
pCislo = (CisloVLoterii *)&y[5];
pCislo->fCislo = x;
printf('%d %d\n', pCislo->au16Cisla[0], pCislo->au16Cisla[1]);
...
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.