Reading element by element works but reading a chunk won't












0














I am trying to determine whether an element exits in a vector using N processes and if true, return all its positions. Each process receives an index and a step. The index is from 0 to "numberOFProcesses -1" and each process check element starting from index, incremented by step.



How it works: Let us assume we have 4 processes. Process 0 checks elements 0,4,8..., process 1 checks 1,5,9... etc.



How did I implement this: I got 2 pipes: one pipes is used for positions; the second pipe is to store the number of occurrences of the target. Whenever a process find the target it increments the number of occurrences and writes the index to the "index" pipe and, finally, upon exiting job, it writes to "occurrences" pipe the number of occurrences, if any, and return true or false. I initially wanted to directly return the number of occurrences but I realized that "WEXITSTATUS" uses only 8 bits and that might be an issue.



The problem: Attempting to read a chunk of size "occurrences" fails or gives invalid results. Reading a value at a time seems to work fine. I have also checked it using valgrind and gdb, but I cannot seem to find the problem. Valgrind reports a ton of issues when attempting to read the chunk, but 0 errors when reading one at time. The reading of occurrences is done only if the process has found the target.



P.S. I know I can leave it like that, but it wouldn't make sense reading multiple times.



Now, for some code:



#include <stdio.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <wait.h>
#include <sys/signal.h>
#include <sys/types.h>
/**
* @brief basic defines
*
*/
#define MAX_RAND 100
#define TRUE 1
#define FALSE 0

#define CHILDREN 0

#define READ 0
#define WRITE 1

int size = 13;
int *array;
int target;
int index_pipe[2];
int occurences_pipe[2];

/**
* @brief this populates the array with random number
*
* @param array the given array
* @param size the size of the array
*/
void populate(int *array, int size)
{
for (int i = 0; i < size; i++)
{
array[i] = rand() % MAX_RAND;
}
}

/**
* @brief this determines whether an elements occurs in an array and writes to pipes the number
* of occurences and the the indexes on which resides the target
*
* @param target the value we are looking for
* @param index the index of the process, i.e. the process id
* @param step the step, i.e. the number of processes
* @return int the search status. This returns true if "target occurs", FALSE otherwise
*/
int search(int target, int index, int step)
{
int i = index;
int numberOfOccurences = 0;

/**
* @brief each process will start at position index and will check values starting with index, incrementing with step
* ex: process 0 will check 0,4,8,12..
* process 1 will check 1,5,9,13...
*/
while (i < size)
{
if (target == array[i])
{
/**
* @brief if the target occues increment the number of occurences and write an index to pipe
*
*/
numberOfOccurences++;
write(index_pipe[WRITE], &i, sizeof(int));
}
i += step;
}

/**
* @brief write occurences to pipe if, and only if, the number of occurences is not 0,
* i.e. we have found the target at least once and return TRUE or FALSE
*
*/
if (numberOfOccurences != 0)
{
write(occurences_pipe[WRITE], &numberOfOccurences, sizeof(int));
return TRUE;
}

return FALSE;
}

/**
* @brief this prints a given array
*
* @param array the array we want to print
* @param size the size of the array
*/
void printArray(int *array, int size)
{
printf("Array: n");
for (int i = 0; i < size; i++)
{
printf("%d ", array[i]);
}
printf("n");
}

/**
* @brief entry point
*
* @return int EXIT_SUCCESS
*/
int main()
{
/**
* @brief initialize and allocate memory
*
*/
size = 13;
array = (int *)malloc(sizeof(int) * size);

pipe(index_pipe);
pipe(occurences_pipe);

int numerOfProccesses = 3;
int target = 15;
int totalOccurences = 0;
int status = -1;
int exit_status = -1;
int occurences = -1;

populate(array, size);
array[size - 1] = target;
printArray(array, size);

size_t processes[numerOfProccesses];

/**
* @brief create childrens and put them to work
*
*/
for (int i = 0; i < numerOfProccesses; i++)
{
processes[i] = fork();
if (CHILDREN == processes[i])
{
/**
* @brief get the search status and exit
*
*/
int exit_status = search(target, i, numerOfProccesses);
exit(exit_status);
}
}

/**
* @brief wait for children to exit
*
*/
for (int i = 0; i < numerOfProccesses; i++)
{
/**
* @brief wait for each children. If a children is done AND it has found taget, i.e. returned TRUE,
* then read the number of occurrences from pipe
*
*/
wait(&status);
if (WIFEXITED(status))
{
exit_status = WEXITSTATUS(status);

if (exit_status == TRUE)
{
read(occurences_pipe[READ], &occurences, sizeof(int));
totalOccurences += occurences;
}
}
}

/**
* @brief if the number of occurrences is 0, then we have'nt found target
*
*/
if (totalOccurences == 0)
{
printf("%d not found n", target);
}
else
{
/**
* @brief else allocate memory for an array of size "occurrences" and read from index pipe
*
*/
printf("Found %d on %d positionsn", target, totalOccurences);
int *indexes = (int *)malloc(sizeof(int) * 3);
// for (int i = 0; i < totalOccurences; i++)
// {
// int value;
// read(index_pipe[READ], &value, sizeof(int));
// printf("Read %d n", value);
// }
int pipe_status;
pipe_status = read(index_pipe[READ], indexes, totalOccurences);
printf("Pipe read %d bytesn", pipe_status);
printArray(indexes, totalOccurences);
}
return 0;
}


Expected output:



Array:
83 86 77 15 93 35 86 92 49 21 62 27 15
Found 15 on 2 positions
Read 3
Read 12
Array:
3 12


I get this when reading a chunk at a time:



Array:
83 86 77 15 93 35 86 92 49 21 62 27 15
Found 15 on 2 positions
Pipe read 2 bytes
Array:
3 0


P.S. I wrote this on a linux machine. I compiled this using: gcc -g -o search search.c -Wextra










share|improve this question



























    0














    I am trying to determine whether an element exits in a vector using N processes and if true, return all its positions. Each process receives an index and a step. The index is from 0 to "numberOFProcesses -1" and each process check element starting from index, incremented by step.



    How it works: Let us assume we have 4 processes. Process 0 checks elements 0,4,8..., process 1 checks 1,5,9... etc.



    How did I implement this: I got 2 pipes: one pipes is used for positions; the second pipe is to store the number of occurrences of the target. Whenever a process find the target it increments the number of occurrences and writes the index to the "index" pipe and, finally, upon exiting job, it writes to "occurrences" pipe the number of occurrences, if any, and return true or false. I initially wanted to directly return the number of occurrences but I realized that "WEXITSTATUS" uses only 8 bits and that might be an issue.



    The problem: Attempting to read a chunk of size "occurrences" fails or gives invalid results. Reading a value at a time seems to work fine. I have also checked it using valgrind and gdb, but I cannot seem to find the problem. Valgrind reports a ton of issues when attempting to read the chunk, but 0 errors when reading one at time. The reading of occurrences is done only if the process has found the target.



    P.S. I know I can leave it like that, but it wouldn't make sense reading multiple times.



    Now, for some code:



    #include <stdio.h>
    #include <stdio.h>
    #include <stdlib.h>
    #include <unistd.h>
    #include <wait.h>
    #include <sys/signal.h>
    #include <sys/types.h>
    /**
    * @brief basic defines
    *
    */
    #define MAX_RAND 100
    #define TRUE 1
    #define FALSE 0

    #define CHILDREN 0

    #define READ 0
    #define WRITE 1

    int size = 13;
    int *array;
    int target;
    int index_pipe[2];
    int occurences_pipe[2];

    /**
    * @brief this populates the array with random number
    *
    * @param array the given array
    * @param size the size of the array
    */
    void populate(int *array, int size)
    {
    for (int i = 0; i < size; i++)
    {
    array[i] = rand() % MAX_RAND;
    }
    }

    /**
    * @brief this determines whether an elements occurs in an array and writes to pipes the number
    * of occurences and the the indexes on which resides the target
    *
    * @param target the value we are looking for
    * @param index the index of the process, i.e. the process id
    * @param step the step, i.e. the number of processes
    * @return int the search status. This returns true if "target occurs", FALSE otherwise
    */
    int search(int target, int index, int step)
    {
    int i = index;
    int numberOfOccurences = 0;

    /**
    * @brief each process will start at position index and will check values starting with index, incrementing with step
    * ex: process 0 will check 0,4,8,12..
    * process 1 will check 1,5,9,13...
    */
    while (i < size)
    {
    if (target == array[i])
    {
    /**
    * @brief if the target occues increment the number of occurences and write an index to pipe
    *
    */
    numberOfOccurences++;
    write(index_pipe[WRITE], &i, sizeof(int));
    }
    i += step;
    }

    /**
    * @brief write occurences to pipe if, and only if, the number of occurences is not 0,
    * i.e. we have found the target at least once and return TRUE or FALSE
    *
    */
    if (numberOfOccurences != 0)
    {
    write(occurences_pipe[WRITE], &numberOfOccurences, sizeof(int));
    return TRUE;
    }

    return FALSE;
    }

    /**
    * @brief this prints a given array
    *
    * @param array the array we want to print
    * @param size the size of the array
    */
    void printArray(int *array, int size)
    {
    printf("Array: n");
    for (int i = 0; i < size; i++)
    {
    printf("%d ", array[i]);
    }
    printf("n");
    }

    /**
    * @brief entry point
    *
    * @return int EXIT_SUCCESS
    */
    int main()
    {
    /**
    * @brief initialize and allocate memory
    *
    */
    size = 13;
    array = (int *)malloc(sizeof(int) * size);

    pipe(index_pipe);
    pipe(occurences_pipe);

    int numerOfProccesses = 3;
    int target = 15;
    int totalOccurences = 0;
    int status = -1;
    int exit_status = -1;
    int occurences = -1;

    populate(array, size);
    array[size - 1] = target;
    printArray(array, size);

    size_t processes[numerOfProccesses];

    /**
    * @brief create childrens and put them to work
    *
    */
    for (int i = 0; i < numerOfProccesses; i++)
    {
    processes[i] = fork();
    if (CHILDREN == processes[i])
    {
    /**
    * @brief get the search status and exit
    *
    */
    int exit_status = search(target, i, numerOfProccesses);
    exit(exit_status);
    }
    }

    /**
    * @brief wait for children to exit
    *
    */
    for (int i = 0; i < numerOfProccesses; i++)
    {
    /**
    * @brief wait for each children. If a children is done AND it has found taget, i.e. returned TRUE,
    * then read the number of occurrences from pipe
    *
    */
    wait(&status);
    if (WIFEXITED(status))
    {
    exit_status = WEXITSTATUS(status);

    if (exit_status == TRUE)
    {
    read(occurences_pipe[READ], &occurences, sizeof(int));
    totalOccurences += occurences;
    }
    }
    }

    /**
    * @brief if the number of occurrences is 0, then we have'nt found target
    *
    */
    if (totalOccurences == 0)
    {
    printf("%d not found n", target);
    }
    else
    {
    /**
    * @brief else allocate memory for an array of size "occurrences" and read from index pipe
    *
    */
    printf("Found %d on %d positionsn", target, totalOccurences);
    int *indexes = (int *)malloc(sizeof(int) * 3);
    // for (int i = 0; i < totalOccurences; i++)
    // {
    // int value;
    // read(index_pipe[READ], &value, sizeof(int));
    // printf("Read %d n", value);
    // }
    int pipe_status;
    pipe_status = read(index_pipe[READ], indexes, totalOccurences);
    printf("Pipe read %d bytesn", pipe_status);
    printArray(indexes, totalOccurences);
    }
    return 0;
    }


    Expected output:



    Array:
    83 86 77 15 93 35 86 92 49 21 62 27 15
    Found 15 on 2 positions
    Read 3
    Read 12
    Array:
    3 12


    I get this when reading a chunk at a time:



    Array:
    83 86 77 15 93 35 86 92 49 21 62 27 15
    Found 15 on 2 positions
    Pipe read 2 bytes
    Array:
    3 0


    P.S. I wrote this on a linux machine. I compiled this using: gcc -g -o search search.c -Wextra










    share|improve this question

























      0












      0








      0


      1





      I am trying to determine whether an element exits in a vector using N processes and if true, return all its positions. Each process receives an index and a step. The index is from 0 to "numberOFProcesses -1" and each process check element starting from index, incremented by step.



      How it works: Let us assume we have 4 processes. Process 0 checks elements 0,4,8..., process 1 checks 1,5,9... etc.



      How did I implement this: I got 2 pipes: one pipes is used for positions; the second pipe is to store the number of occurrences of the target. Whenever a process find the target it increments the number of occurrences and writes the index to the "index" pipe and, finally, upon exiting job, it writes to "occurrences" pipe the number of occurrences, if any, and return true or false. I initially wanted to directly return the number of occurrences but I realized that "WEXITSTATUS" uses only 8 bits and that might be an issue.



      The problem: Attempting to read a chunk of size "occurrences" fails or gives invalid results. Reading a value at a time seems to work fine. I have also checked it using valgrind and gdb, but I cannot seem to find the problem. Valgrind reports a ton of issues when attempting to read the chunk, but 0 errors when reading one at time. The reading of occurrences is done only if the process has found the target.



      P.S. I know I can leave it like that, but it wouldn't make sense reading multiple times.



      Now, for some code:



      #include <stdio.h>
      #include <stdio.h>
      #include <stdlib.h>
      #include <unistd.h>
      #include <wait.h>
      #include <sys/signal.h>
      #include <sys/types.h>
      /**
      * @brief basic defines
      *
      */
      #define MAX_RAND 100
      #define TRUE 1
      #define FALSE 0

      #define CHILDREN 0

      #define READ 0
      #define WRITE 1

      int size = 13;
      int *array;
      int target;
      int index_pipe[2];
      int occurences_pipe[2];

      /**
      * @brief this populates the array with random number
      *
      * @param array the given array
      * @param size the size of the array
      */
      void populate(int *array, int size)
      {
      for (int i = 0; i < size; i++)
      {
      array[i] = rand() % MAX_RAND;
      }
      }

      /**
      * @brief this determines whether an elements occurs in an array and writes to pipes the number
      * of occurences and the the indexes on which resides the target
      *
      * @param target the value we are looking for
      * @param index the index of the process, i.e. the process id
      * @param step the step, i.e. the number of processes
      * @return int the search status. This returns true if "target occurs", FALSE otherwise
      */
      int search(int target, int index, int step)
      {
      int i = index;
      int numberOfOccurences = 0;

      /**
      * @brief each process will start at position index and will check values starting with index, incrementing with step
      * ex: process 0 will check 0,4,8,12..
      * process 1 will check 1,5,9,13...
      */
      while (i < size)
      {
      if (target == array[i])
      {
      /**
      * @brief if the target occues increment the number of occurences and write an index to pipe
      *
      */
      numberOfOccurences++;
      write(index_pipe[WRITE], &i, sizeof(int));
      }
      i += step;
      }

      /**
      * @brief write occurences to pipe if, and only if, the number of occurences is not 0,
      * i.e. we have found the target at least once and return TRUE or FALSE
      *
      */
      if (numberOfOccurences != 0)
      {
      write(occurences_pipe[WRITE], &numberOfOccurences, sizeof(int));
      return TRUE;
      }

      return FALSE;
      }

      /**
      * @brief this prints a given array
      *
      * @param array the array we want to print
      * @param size the size of the array
      */
      void printArray(int *array, int size)
      {
      printf("Array: n");
      for (int i = 0; i < size; i++)
      {
      printf("%d ", array[i]);
      }
      printf("n");
      }

      /**
      * @brief entry point
      *
      * @return int EXIT_SUCCESS
      */
      int main()
      {
      /**
      * @brief initialize and allocate memory
      *
      */
      size = 13;
      array = (int *)malloc(sizeof(int) * size);

      pipe(index_pipe);
      pipe(occurences_pipe);

      int numerOfProccesses = 3;
      int target = 15;
      int totalOccurences = 0;
      int status = -1;
      int exit_status = -1;
      int occurences = -1;

      populate(array, size);
      array[size - 1] = target;
      printArray(array, size);

      size_t processes[numerOfProccesses];

      /**
      * @brief create childrens and put them to work
      *
      */
      for (int i = 0; i < numerOfProccesses; i++)
      {
      processes[i] = fork();
      if (CHILDREN == processes[i])
      {
      /**
      * @brief get the search status and exit
      *
      */
      int exit_status = search(target, i, numerOfProccesses);
      exit(exit_status);
      }
      }

      /**
      * @brief wait for children to exit
      *
      */
      for (int i = 0; i < numerOfProccesses; i++)
      {
      /**
      * @brief wait for each children. If a children is done AND it has found taget, i.e. returned TRUE,
      * then read the number of occurrences from pipe
      *
      */
      wait(&status);
      if (WIFEXITED(status))
      {
      exit_status = WEXITSTATUS(status);

      if (exit_status == TRUE)
      {
      read(occurences_pipe[READ], &occurences, sizeof(int));
      totalOccurences += occurences;
      }
      }
      }

      /**
      * @brief if the number of occurrences is 0, then we have'nt found target
      *
      */
      if (totalOccurences == 0)
      {
      printf("%d not found n", target);
      }
      else
      {
      /**
      * @brief else allocate memory for an array of size "occurrences" and read from index pipe
      *
      */
      printf("Found %d on %d positionsn", target, totalOccurences);
      int *indexes = (int *)malloc(sizeof(int) * 3);
      // for (int i = 0; i < totalOccurences; i++)
      // {
      // int value;
      // read(index_pipe[READ], &value, sizeof(int));
      // printf("Read %d n", value);
      // }
      int pipe_status;
      pipe_status = read(index_pipe[READ], indexes, totalOccurences);
      printf("Pipe read %d bytesn", pipe_status);
      printArray(indexes, totalOccurences);
      }
      return 0;
      }


      Expected output:



      Array:
      83 86 77 15 93 35 86 92 49 21 62 27 15
      Found 15 on 2 positions
      Read 3
      Read 12
      Array:
      3 12


      I get this when reading a chunk at a time:



      Array:
      83 86 77 15 93 35 86 92 49 21 62 27 15
      Found 15 on 2 positions
      Pipe read 2 bytes
      Array:
      3 0


      P.S. I wrote this on a linux machine. I compiled this using: gcc -g -o search search.c -Wextra










      share|improve this question













      I am trying to determine whether an element exits in a vector using N processes and if true, return all its positions. Each process receives an index and a step. The index is from 0 to "numberOFProcesses -1" and each process check element starting from index, incremented by step.



      How it works: Let us assume we have 4 processes. Process 0 checks elements 0,4,8..., process 1 checks 1,5,9... etc.



      How did I implement this: I got 2 pipes: one pipes is used for positions; the second pipe is to store the number of occurrences of the target. Whenever a process find the target it increments the number of occurrences and writes the index to the "index" pipe and, finally, upon exiting job, it writes to "occurrences" pipe the number of occurrences, if any, and return true or false. I initially wanted to directly return the number of occurrences but I realized that "WEXITSTATUS" uses only 8 bits and that might be an issue.



      The problem: Attempting to read a chunk of size "occurrences" fails or gives invalid results. Reading a value at a time seems to work fine. I have also checked it using valgrind and gdb, but I cannot seem to find the problem. Valgrind reports a ton of issues when attempting to read the chunk, but 0 errors when reading one at time. The reading of occurrences is done only if the process has found the target.



      P.S. I know I can leave it like that, but it wouldn't make sense reading multiple times.



      Now, for some code:



      #include <stdio.h>
      #include <stdio.h>
      #include <stdlib.h>
      #include <unistd.h>
      #include <wait.h>
      #include <sys/signal.h>
      #include <sys/types.h>
      /**
      * @brief basic defines
      *
      */
      #define MAX_RAND 100
      #define TRUE 1
      #define FALSE 0

      #define CHILDREN 0

      #define READ 0
      #define WRITE 1

      int size = 13;
      int *array;
      int target;
      int index_pipe[2];
      int occurences_pipe[2];

      /**
      * @brief this populates the array with random number
      *
      * @param array the given array
      * @param size the size of the array
      */
      void populate(int *array, int size)
      {
      for (int i = 0; i < size; i++)
      {
      array[i] = rand() % MAX_RAND;
      }
      }

      /**
      * @brief this determines whether an elements occurs in an array and writes to pipes the number
      * of occurences and the the indexes on which resides the target
      *
      * @param target the value we are looking for
      * @param index the index of the process, i.e. the process id
      * @param step the step, i.e. the number of processes
      * @return int the search status. This returns true if "target occurs", FALSE otherwise
      */
      int search(int target, int index, int step)
      {
      int i = index;
      int numberOfOccurences = 0;

      /**
      * @brief each process will start at position index and will check values starting with index, incrementing with step
      * ex: process 0 will check 0,4,8,12..
      * process 1 will check 1,5,9,13...
      */
      while (i < size)
      {
      if (target == array[i])
      {
      /**
      * @brief if the target occues increment the number of occurences and write an index to pipe
      *
      */
      numberOfOccurences++;
      write(index_pipe[WRITE], &i, sizeof(int));
      }
      i += step;
      }

      /**
      * @brief write occurences to pipe if, and only if, the number of occurences is not 0,
      * i.e. we have found the target at least once and return TRUE or FALSE
      *
      */
      if (numberOfOccurences != 0)
      {
      write(occurences_pipe[WRITE], &numberOfOccurences, sizeof(int));
      return TRUE;
      }

      return FALSE;
      }

      /**
      * @brief this prints a given array
      *
      * @param array the array we want to print
      * @param size the size of the array
      */
      void printArray(int *array, int size)
      {
      printf("Array: n");
      for (int i = 0; i < size; i++)
      {
      printf("%d ", array[i]);
      }
      printf("n");
      }

      /**
      * @brief entry point
      *
      * @return int EXIT_SUCCESS
      */
      int main()
      {
      /**
      * @brief initialize and allocate memory
      *
      */
      size = 13;
      array = (int *)malloc(sizeof(int) * size);

      pipe(index_pipe);
      pipe(occurences_pipe);

      int numerOfProccesses = 3;
      int target = 15;
      int totalOccurences = 0;
      int status = -1;
      int exit_status = -1;
      int occurences = -1;

      populate(array, size);
      array[size - 1] = target;
      printArray(array, size);

      size_t processes[numerOfProccesses];

      /**
      * @brief create childrens and put them to work
      *
      */
      for (int i = 0; i < numerOfProccesses; i++)
      {
      processes[i] = fork();
      if (CHILDREN == processes[i])
      {
      /**
      * @brief get the search status and exit
      *
      */
      int exit_status = search(target, i, numerOfProccesses);
      exit(exit_status);
      }
      }

      /**
      * @brief wait for children to exit
      *
      */
      for (int i = 0; i < numerOfProccesses; i++)
      {
      /**
      * @brief wait for each children. If a children is done AND it has found taget, i.e. returned TRUE,
      * then read the number of occurrences from pipe
      *
      */
      wait(&status);
      if (WIFEXITED(status))
      {
      exit_status = WEXITSTATUS(status);

      if (exit_status == TRUE)
      {
      read(occurences_pipe[READ], &occurences, sizeof(int));
      totalOccurences += occurences;
      }
      }
      }

      /**
      * @brief if the number of occurrences is 0, then we have'nt found target
      *
      */
      if (totalOccurences == 0)
      {
      printf("%d not found n", target);
      }
      else
      {
      /**
      * @brief else allocate memory for an array of size "occurrences" and read from index pipe
      *
      */
      printf("Found %d on %d positionsn", target, totalOccurences);
      int *indexes = (int *)malloc(sizeof(int) * 3);
      // for (int i = 0; i < totalOccurences; i++)
      // {
      // int value;
      // read(index_pipe[READ], &value, sizeof(int));
      // printf("Read %d n", value);
      // }
      int pipe_status;
      pipe_status = read(index_pipe[READ], indexes, totalOccurences);
      printf("Pipe read %d bytesn", pipe_status);
      printArray(indexes, totalOccurences);
      }
      return 0;
      }


      Expected output:



      Array:
      83 86 77 15 93 35 86 92 49 21 62 27 15
      Found 15 on 2 positions
      Read 3
      Read 12
      Array:
      3 12


      I get this when reading a chunk at a time:



      Array:
      83 86 77 15 93 35 86 92 49 21 62 27 15
      Found 15 on 2 positions
      Pipe read 2 bytes
      Array:
      3 0


      P.S. I wrote this on a linux machine. I compiled this using: gcc -g -o search search.c -Wextra







      c pipe fork






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 12 '18 at 21:16









      CyberFoxCyberFox

      676




      676
























          1 Answer
          1






          active

          oldest

          votes


















          1














          ...
          read(occurences_pipe[READ], &occurences, sizeof(int));
          totalOccurences += occurences;

          int *indexes = (int *)malloc(sizeof(int) * 3);
          read(index_pipe[READ], indexes, totalOccurences);


          Well, you are reading an unknown number of bytes, which is the sum of occurences of the numbers found within each process from the pipe and saving it into sizeof(int) * 3 bytes, which can possibly overflow. Also the totalOccurences is the sum from all the processes. I think you meant to:



          int *indexes = (int *)malloc(sizeof(int) * totalOccurences);
          read(index_pipe[READ], indexes, sizeof(int) * totalOccurences);



          1. I like this idea of concurency and single pipes to communicate with multiple processes. You can speed things up a bit, by using realloc + read(index_pipe[READ], ..., sizeof(int) * occurences) right in the reading if (exit_status == TRUE) loop. That way you could earlier free the data buffered in pipe.

          2. I don't think there is the need for occurences_pipe if you are just interested in the sum of all occurences. You can just set O_NONBLOCK on the index_pipe[READ], and read from it byte by byte (or chunk by chunk) until all threads will finish and the read will return 0. The sum of all occurences is the number of bytes read from index_pipe after all threads exited divided by sizeof(int).

          3. I think that threads would be better suited for such task, you are copying the whole array between processes on fork, when using pthreads each thread would use the same memory.

          4. And, for the love of K&R, don't cast the result of malloc.






          share|improve this answer

















          • 1




            I totally missed the part where I missr-ead from the occurrences pipe. Also, thanks for the tips on casting, I always thought it would e better to cast the results.
            – CyberFox
            Nov 13 '18 at 8:10











          Your Answer






          StackExchange.ifUsing("editor", function () {
          StackExchange.using("externalEditor", function () {
          StackExchange.using("snippets", function () {
          StackExchange.snippets.init();
          });
          });
          }, "code-snippets");

          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "1"
          };
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function() {
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled) {
          StackExchange.using("snippets", function() {
          createEditor();
          });
          }
          else {
          createEditor();
          }
          });

          function createEditor() {
          StackExchange.prepareEditor({
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader: {
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          },
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          });


          }
          });














          draft saved

          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53270235%2freading-element-by-element-works-but-reading-a-chunk-wont%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          1














          ...
          read(occurences_pipe[READ], &occurences, sizeof(int));
          totalOccurences += occurences;

          int *indexes = (int *)malloc(sizeof(int) * 3);
          read(index_pipe[READ], indexes, totalOccurences);


          Well, you are reading an unknown number of bytes, which is the sum of occurences of the numbers found within each process from the pipe and saving it into sizeof(int) * 3 bytes, which can possibly overflow. Also the totalOccurences is the sum from all the processes. I think you meant to:



          int *indexes = (int *)malloc(sizeof(int) * totalOccurences);
          read(index_pipe[READ], indexes, sizeof(int) * totalOccurences);



          1. I like this idea of concurency and single pipes to communicate with multiple processes. You can speed things up a bit, by using realloc + read(index_pipe[READ], ..., sizeof(int) * occurences) right in the reading if (exit_status == TRUE) loop. That way you could earlier free the data buffered in pipe.

          2. I don't think there is the need for occurences_pipe if you are just interested in the sum of all occurences. You can just set O_NONBLOCK on the index_pipe[READ], and read from it byte by byte (or chunk by chunk) until all threads will finish and the read will return 0. The sum of all occurences is the number of bytes read from index_pipe after all threads exited divided by sizeof(int).

          3. I think that threads would be better suited for such task, you are copying the whole array between processes on fork, when using pthreads each thread would use the same memory.

          4. And, for the love of K&R, don't cast the result of malloc.






          share|improve this answer

















          • 1




            I totally missed the part where I missr-ead from the occurrences pipe. Also, thanks for the tips on casting, I always thought it would e better to cast the results.
            – CyberFox
            Nov 13 '18 at 8:10
















          1














          ...
          read(occurences_pipe[READ], &occurences, sizeof(int));
          totalOccurences += occurences;

          int *indexes = (int *)malloc(sizeof(int) * 3);
          read(index_pipe[READ], indexes, totalOccurences);


          Well, you are reading an unknown number of bytes, which is the sum of occurences of the numbers found within each process from the pipe and saving it into sizeof(int) * 3 bytes, which can possibly overflow. Also the totalOccurences is the sum from all the processes. I think you meant to:



          int *indexes = (int *)malloc(sizeof(int) * totalOccurences);
          read(index_pipe[READ], indexes, sizeof(int) * totalOccurences);



          1. I like this idea of concurency and single pipes to communicate with multiple processes. You can speed things up a bit, by using realloc + read(index_pipe[READ], ..., sizeof(int) * occurences) right in the reading if (exit_status == TRUE) loop. That way you could earlier free the data buffered in pipe.

          2. I don't think there is the need for occurences_pipe if you are just interested in the sum of all occurences. You can just set O_NONBLOCK on the index_pipe[READ], and read from it byte by byte (or chunk by chunk) until all threads will finish and the read will return 0. The sum of all occurences is the number of bytes read from index_pipe after all threads exited divided by sizeof(int).

          3. I think that threads would be better suited for such task, you are copying the whole array between processes on fork, when using pthreads each thread would use the same memory.

          4. And, for the love of K&R, don't cast the result of malloc.






          share|improve this answer

















          • 1




            I totally missed the part where I missr-ead from the occurrences pipe. Also, thanks for the tips on casting, I always thought it would e better to cast the results.
            – CyberFox
            Nov 13 '18 at 8:10














          1












          1








          1






          ...
          read(occurences_pipe[READ], &occurences, sizeof(int));
          totalOccurences += occurences;

          int *indexes = (int *)malloc(sizeof(int) * 3);
          read(index_pipe[READ], indexes, totalOccurences);


          Well, you are reading an unknown number of bytes, which is the sum of occurences of the numbers found within each process from the pipe and saving it into sizeof(int) * 3 bytes, which can possibly overflow. Also the totalOccurences is the sum from all the processes. I think you meant to:



          int *indexes = (int *)malloc(sizeof(int) * totalOccurences);
          read(index_pipe[READ], indexes, sizeof(int) * totalOccurences);



          1. I like this idea of concurency and single pipes to communicate with multiple processes. You can speed things up a bit, by using realloc + read(index_pipe[READ], ..., sizeof(int) * occurences) right in the reading if (exit_status == TRUE) loop. That way you could earlier free the data buffered in pipe.

          2. I don't think there is the need for occurences_pipe if you are just interested in the sum of all occurences. You can just set O_NONBLOCK on the index_pipe[READ], and read from it byte by byte (or chunk by chunk) until all threads will finish and the read will return 0. The sum of all occurences is the number of bytes read from index_pipe after all threads exited divided by sizeof(int).

          3. I think that threads would be better suited for such task, you are copying the whole array between processes on fork, when using pthreads each thread would use the same memory.

          4. And, for the love of K&R, don't cast the result of malloc.






          share|improve this answer












          ...
          read(occurences_pipe[READ], &occurences, sizeof(int));
          totalOccurences += occurences;

          int *indexes = (int *)malloc(sizeof(int) * 3);
          read(index_pipe[READ], indexes, totalOccurences);


          Well, you are reading an unknown number of bytes, which is the sum of occurences of the numbers found within each process from the pipe and saving it into sizeof(int) * 3 bytes, which can possibly overflow. Also the totalOccurences is the sum from all the processes. I think you meant to:



          int *indexes = (int *)malloc(sizeof(int) * totalOccurences);
          read(index_pipe[READ], indexes, sizeof(int) * totalOccurences);



          1. I like this idea of concurency and single pipes to communicate with multiple processes. You can speed things up a bit, by using realloc + read(index_pipe[READ], ..., sizeof(int) * occurences) right in the reading if (exit_status == TRUE) loop. That way you could earlier free the data buffered in pipe.

          2. I don't think there is the need for occurences_pipe if you are just interested in the sum of all occurences. You can just set O_NONBLOCK on the index_pipe[READ], and read from it byte by byte (or chunk by chunk) until all threads will finish and the read will return 0. The sum of all occurences is the number of bytes read from index_pipe after all threads exited divided by sizeof(int).

          3. I think that threads would be better suited for such task, you are copying the whole array between processes on fork, when using pthreads each thread would use the same memory.

          4. And, for the love of K&R, don't cast the result of malloc.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 12 '18 at 21:59









          Kamil CukKamil Cuk

          9,3331527




          9,3331527








          • 1




            I totally missed the part where I missr-ead from the occurrences pipe. Also, thanks for the tips on casting, I always thought it would e better to cast the results.
            – CyberFox
            Nov 13 '18 at 8:10














          • 1




            I totally missed the part where I missr-ead from the occurrences pipe. Also, thanks for the tips on casting, I always thought it would e better to cast the results.
            – CyberFox
            Nov 13 '18 at 8:10








          1




          1




          I totally missed the part where I missr-ead from the occurrences pipe. Also, thanks for the tips on casting, I always thought it would e better to cast the results.
          – CyberFox
          Nov 13 '18 at 8:10




          I totally missed the part where I missr-ead from the occurrences pipe. Also, thanks for the tips on casting, I always thought it would e better to cast the results.
          – CyberFox
          Nov 13 '18 at 8:10


















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Stack Overflow!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid



          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.


          To learn more, see our tips on writing great answers.





          Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


          Please pay close attention to the following guidance:


          • Please be sure to answer the question. Provide details and share your research!

          But avoid



          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53270235%2freading-element-by-element-works-but-reading-a-chunk-wont%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Florida Star v. B. J. F.

          Danny Elfman

          Lugert, Oklahoma