dev-resources.site
for different kinds of informations.
DATATYPES IN C (double, long double, void, bool)
In the previous story, we talked about some datatypes like int, char, and float. We are going to see more datatypes in this article.
double —
Size:
Thedouble
data type typically requires 8 bytes of memory on most systems, providing more precision compared to the float data type.Declaration:
double double_variable;
Example
double pi = 3.14159265359;
-
Initialization:
You can initialize a
double
variable when declaring it.
double temperature = 98.6;
-
Operations:
double
supports standard arithmetic operations, like addition, subtraction, multiplication, and division:
double x = 5.0;
double y = 2.5;
double result = x / y; // result is now 2.0
-
Output Formatting:
When printing or displaying the value of a double, weuse the
%lf
format specifier in functions likeprintf
:
printf("The value of pi is %lf\n", pi);
- Scientific Notation: Numbers can be expressed in scientific notation, using the e or E character to represent the exponent.
double scientific_number = 1.23e-4; // Equivalent to 0.000123
Precision:
double
provides double-precision floating-point numbers, offering a larger range and higher precision than the float data type.
It is suitable for applications where higher precision is required, such as scientific and engineering computations.Limits:
The<float.h>
header file provides constants that represent the limits of various floating-point data types. For double, you can useDBL_MIN
andDBL_MAX
to get the minimum and maximum representable values.
#include <float.h>
printf("Minimum value of double: %e\n", DBL_MIN);
printf("Maximum value of double: %e\n", DBL_MAX);
long double —
The long double data type represents extended-precision floating-point numbers.
It offers extended-precision floating-point numbers, depending on the platform.
Size:
The size of a long double variable is platform-dependent and is typically larger than that of double. It can vary, but it’s often 8 bytes or more.Declaration:
To declare a long double variable, you use the following syntax:
long double long_double_variable;
Example
long double pi = 3.14159265358979323846;
-
Initialization:
Similar to
double
, you can initializelong double
at the time of declaration:
long double large_number = 12345678901234567890.1234567890;
-
Operations:
long double
variables support standard arithmetic operations.
long double x = 5.0;
long double y = 2.5;
long double result = x / y; // result is now 2.0
-
Output Formatting:
When printing or displaying the value of a long double, we use the
%Lf
format specifier in functions likeprintf
:
printf("The value of pi is %Lf\n", pi);
-
Scientific Notation:
As with
double
,long double
supports scientific notation:
long double scientific_number = 1.23e-4; // Equivalent to 0.000123
Precision:
long double provides the highest precision among floating-point data types in C. It is commonly used in applications that demand extremely high accuracy, such as scientific research and complex simulations.Limits:
The<float.h>
header file provides constants that represent the limits of various floating-point data types. Forlong double
, you can useLDBL_MIN
andLDBL_MAX
to get the minimum and maximum representable values.
#include <float.h>
printf("Minimum value of long double: %Le\n", LDBL_MIN);
printf("Maximum value of long double: %Le\n", LDBL_MAX);
void —
void data type is a special data type that is used to indicate the absence of a specific type.
- No Value: Use void for functions that don’t return a value.
void myFunction() {
// Function does not return any value
}
-
No Arguments:
When used as a function parameter,
void
indicates that the function does not expect any arguments.
void printMessage(void) {
printf("Hello, World!\n");
}
- Pointer to void (Generic Pointer): A pointer of type void* (generic pointer) can point to objects of any data type. It is often used in functions that need to handle various data types.
void printValue(void *ptr, char type) {
// Function to print values of different types using a generic pointer
}
-
Incomplete Type:
void
can be used as an incomplete type when declaring pointers.
void *ptr;
- Return Type in Functions: In function declarations, void indicates that the function does not return a value.
void myFunction(void);
-
Dynamic Memory:
void*
is commonly used for allocating memory dynamically (withmalloc
,calloc
, etc.) because it can be cast to any pointer type.
void *ptr = malloc(sizeof(int));
- Generic Programming: In some programming paradigms, void is used in generic programming where functions or data structures can work with multiple data types.
bool —
The bool type was introduced in C99. Before that, C did not have a native boolean type. However, starting with the C99 standard, a header was introduced that includes a boolean type and boolean constants.
-
Header Inclusion:
To use
bool
in C, include the<stdbool.h>
header.
#include <stdbool.h>
-
Boolean Type:
The bool type can take values
true
orfalse
.
bool isReady = true;
bool isValid = false;
-
Boolean Constants:
The header defines two constants:
true
andfalse
.
#include <stdbool.h>
bool isReady = true;
bool isValid = false;
-
Operations:
The
bool
type is often used in conditions and logical expressions.
#include <stdbool.h>
bool isReady = true;
if (isReady) {
// Code executed if isReady is true
}
- Functions Returning bool:
#include <stdbool.h>
bool isEven(int number) {
return (number % 2 == 0);
}
Compatibility:
While C99 and later standards have native support for bool, some older compilers or projects might not fully support it. In such cases, you - boolean variables represented usingint
, where 0 is equivalent tofalse
and non-zero totrue
.Conditional Expressions:
bool
is commonly used in conditional expressions to improve code readability.
#include <stdbool.h>
bool isPositive(int number) {
return (number > 0);
}
Understanding the different data types in C, like double
, long double
, void
, and bool
, is crucial for writing efficient and accurate code. Each datatype has its unique properties and is suited for specific tasks—whether it's handling precise calculations with double
and long double
, defining functions with no return type using void
, or managing logic with bool
. Mastering these concepts will allow you to build more robust and flexible programs, especially as you tackle more complex problems in scientific computing, system programming, or everyday application development.
Further Resources
To continue your journey in mastering C and its data types, here are some valuable resources:
Books:
The C Programming Language by Brian W. Kernighan and Dennis M. Ritchie (also known as K&R) — A classic text that introduces C with clarity and depth.
Online Tutorials:
Learn-C.org — An interactive platform to practice C programming.
Video Resources:
YouTube Channel: freeCodeCamp — Provides free tutorials on C programming, among many other languages.
By diving into these resources, you’ll deepen your understanding of C and strengthen your programming skills. Keep experimenting and coding!
Featured ones: