Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6662447
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 26, 20262026-05-26T02:23:26+00:00 2026-05-26T02:23:26+00:00

I am writing functions that serialize/deserialize a large data structure for efficient reloading later

  • 0

I am writing functions that serialize/deserialize a large data structure for efficient reloading later on. There is a particular set of decimal numbers for which precision is not a huge deal, and I would like to store them in 4 bytes of binary data.

For most, reading the bytes into a buffer and using memcpy to place them into a float is sufficient, and is the most common solution I’ve found. However, this is not portable, as floats on the systems this software is meant for are not guaranteed to be 4 bytes in size.

What I would like is something very portable (which is one of the reasons I’m limited to C89). I’m not wedded to 4 byte storage, but it is an attractive option to me. I am pretty wholly against storing the numbers as strings. I’m familiar with endianness issues, and such things are already taken into account.

What I am looking for, therefore, is a system-independent way to store and retrieve floating point numbers in a small amount of binary data (preferably around 4 bytes). I, in my foolishness, imagined this would be the easiest part of this task, since it seems like such a common problem, but popular search engines and various reference books have provided no material assistance.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-26T02:23:26+00:00Added an answer on May 26, 2026 at 2:23 am

    You could store them in 32 bit IEEE float format (or a very close approximation to it, for instance you might what to restrict denorms and NaNs). Then have each platform adjust as necessary to coerce its own float type to that format and back.

    Of course there will be some loss of accuracy, but that’s inevitable anyway if you’re transferring float values of difference precisions from one system to another.

    It should be possible to write portable code to find the closest IEEE value to a native float value, and vice-versa, if that’s required. You wouldn’t really want to use it, though, because it would probably be far less efficient than code that takes advantage of knowing the float format. In the common case where the platform uses an IEEE representation it’s a no-op or a simple narrowing/widening conversion. Even in the worst case you’re likely to encounter, as long as it’s a binary fraction you basically just have to extract the sign, exponent and significand bits and do the right thing with them (discard bits from the significand if it’s too big, adjust the bias and possibly the width of the exponent, do the right thing with underflow and overflow).

    If you want to avoid losing accuracy in the case where the file is saved and then reloaded on the same system (but that system doesn’t use 32bit IEEE), you could look at storing some data indicating the format in the file (size of each value, number of bits of significand and exponent), then store each value at native precision, so that it only gets rounded if it’s ever loaded onto a less-precise system. I don’t know whether ASN.1 has a standard to encode floating-point values along these lines, but it’s the kind of complicated trickery I’d expect from it.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Coming from a PHP background, I'm used to writing small functions that return a
I've been writing some jQuery functions that have JavaScript variables and looping, etc inside
I'm writing some code that uses some unmanaged calls into user32 functions such as
I've gotten used to writing functions that work like this: def f(): if sunny:
recently I'm writing some functions that I take from Haskell and translate into Java.
I'm writing some C++ code that will have to send data over TCP/IP. I
im interested i just finished writing a program and one of the functions that
when writing small functions I often have the case that some parameters are given
I frequently end up writing SubscribeToEvents() and UnsubscribeEvents() functions that are called in my
Writing Scala code, I regularly encounter cases where I have processor functions that operate

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.