Anish Shah
Anish Shah

Reputation: 163

Getting an invalid read size error for int variable pointer when using valgrind

I am getting the following error while using valgrind which I am unable to debug.

  Memcheck, a memory error detector
==9215== Copyright (C) 2002-2012, and GNU GPL'd, by Julian Seward et al.
==9215== Using Valgrind-3.8.1 and LibVEX; rerun with -h for copyright info
==9215== Command: ./memleak 1
==9215== 
==9215== Invalid read of size 4
==9215==    at 0x400CEC: test1(int*, int) (memleak.cpp:11)
==9215==    by 0x400F0F: main (memleak.cpp:55)
==9215==  Address 0x5a1a05c is 0 bytes after a block of size 28 alloc'd
==9215==    at 0x4C2AFE7: operator new[](unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==9215==    by 0x400EAD: main (memleak.cpp:51)
==9215== 
Test 1 sum is 475
==9215== 
==9215== HEAP SUMMARY:
==9215==     in use at exit: 0 bytes in 0 blocks
==9215==   total heap usage: 1 allocs, 1 frees, 28 bytes allocated
==9215== 
==9215== All heap blocks were freed -- no leaks are possible
==9215== 
==9215== For counts of detected and suppressed errors, rerun with: -v
==9215== ERROR SUMMARY: 1 errors from 1 contexts (suppressed: 2 from 2)

My code is:

#include <iostream>
#include <cstdlib>
#include <cstring>
using namespace std;

// sum an array of numbers
int test1(int *data, int len)
{
  int sum = 0;
  for(int i=0; i <= len; i++){
    sum += data[i];
  }
  return sum;
}

// Allocate a random number array
char* test2_init()
{
  char buf[80];
  cout << "Enter a word: ";
  cin >> buf;
  char* mydat = new char[strlen(buf)+1];
strcpy(mydat, buf);
return mydat;
}
char* test2_reverse(char* word)
{
  int len = strlen(word);
  char* otherword = new char[len+1];

  for(int i=0; (unsigned)i < strlen(word); i++){
    otherword[i] = word[len-i-1];
  }
  otherword[len+1] = '\0';
  delete [] word;
  return otherword;
}

int main(int argc, char* argv[])
{
  if(argc < 2){
    cerr << "Please enter the test number you want to run [1-2]" << endl;
    return 1;
  }
  const int len = 7;
  int test = atoi(argv[1]);

  if(test == 1){
    // Test should sum up the array values and print it
    int *data = 0;
    data=new int[len];
    for(int i=0; i < len; i++){
      data[i] = rand()%100;
    }
    int sum = test1(data, len); 
    delete [] data;
    cout << "Test 1 sum is " << sum << endl;
  }

  else if(test == 2){
    // Test should create a random string & then reverse a copy
    char* myword = test2_init();
    cout << "myword is " << myword << endl;

    char* otherword = test2_reverse(myword);    
    cout << "otherword is " << otherword << endl;

    delete [] myword;
    delete [] otherword;
  }
  else {
    cout << "Unknown test number" << endl;
  }

  return 0;
}

Unable to figure out the reason for the invalid read of size 4 error. I know I should be using vectors, but I want to use new for this project.

Upvotes: 0

Views: 317

Answers (2)

Ed Swangren
Ed Swangren

Reputation: 124790

for(int i=0; i <= len; i++){
    sum += data[i];
}

Should be

for(int i=0; i < len; i++){
    sum += data[i];
}

You're reading one past the end of the array. Indices 0...len are valid, data[len] is not.

Upvotes: 1

Mike Seymour
Mike Seymour

Reputation: 254751

for(int i=0; i <= len; i++)
                ^

That access all indexes up to and including len. len itself is past the end of the array or, as Valgrind puts it, "0 bytes after a block". The test should be the canonical i < len.

Upvotes: 2

Related Questions