Mohd Shahril
Mohd Shahril

Reputation: 2327

initial value of reference to non-const must be an lvalue

I'm trying to send value into function using reference pointer but it gave me a completely non-obvious error

#include "stdafx.h"
#include <iostream>

using namespace std;

void test(float *&x){
    
    *x = 1000;
}

int main(){
    float nKByte = 100.0;
    test(&nKByte);
    cout << nKByte << " megabytes" << endl;
    cin.get();
}

Error : initial value of reference to non-const must be an lvalue

I have no idea what I must do to repair above code, can someone give me some ideas on how to fix that code?

Upvotes: 74

Views: 212355

Answers (5)

mada
mada

Reputation: 1985

Simply, initializers of references are expected to be objects not their addresses, but if you need to assign a reference to otherwise (like your code above), declare this reference as const. Why const? because if not, the compiler does think that you need to, later on, modify the pointer itself not what it's pointing to.

Upvotes: 1

Anurag Maurya
Anurag Maurya

Reputation: 3

Simply replace test(&nKByte); with test(nKByte); in main function

Upvotes: 0

Sergey Kalinichenko
Sergey Kalinichenko

Reputation: 726599

When you pass a pointer by a non-const reference, you are telling the compiler that you are going to modify that pointer's value. Your code does not do that, but the compiler thinks that it does, or plans to do it in the future.

To fix this error, either declare x constant

// This tells the compiler that you are not planning to modify the pointer
// passed by reference
void test(float * const &x){
    *x = 1000;
}

or make a variable to which you assign a pointer to nKByte before calling test:

float nKByte = 100.0;
// If "test()" decides to modify `x`, the modification will be reflected in nKBytePtr
float *nKBytePtr = &nKByte;
test(nKBytePtr);

Upvotes: 83

wilx
wilx

Reputation: 18228

The &nKByte creates a temporary value, which cannot be bound to a reference to non-const.

You could change void test(float *&x) to void test(float * const &x) or you could just drop the pointer altogether and use void test(float &x); /*...*/ test(nKByte);.

Upvotes: 15

Some programmer dude
Some programmer dude

Reputation: 409176

When you call test with &nKByte, the address-of operator creates a temporary value, and you can't normally have references to temporary values because they are, well, temporary.

Either do not use a reference for the argument, or better yet don't use a pointer.

Upvotes: 10

Related Questions