Skip to main content

Pointer to Function C and C++

Hi this is my first technical post , really i find this topic very interesting and i like it .
actually I worked now on good project which utilize my Genetic algorithms , neural networks and parallel computing knowledge . when searching i hit in this topic .

pointers to function :
who should read this article are computer science students and programing Students
introduction :
 you can write good code without knowing any thing about pointers , but if you used pointers you will write all your codes with pointers , it is best invention after electricity , it will attract you , and you will feel the infinite happiness  .

what is pointer ?
you know int , float , double you can think on this data type as box which contain some value . but pointers is different it stores the reference of this value -memory address - then you can access the value in this pointer by dereference it .

declare pointer int *ptr;
dereference pointer *ptr ; but take care you have to assign value to the pointer before dereference it to avoid memory explosion .

pointers are amazing in passing arrays to functions .
are amazing two to create dynamic arrays , it can be deleted and free its memory .

about today topic :
Arrays can used to pass function as an argument for another function .
problem statement :
in math you can apply this equation using the two functions f &g  f(g(x))  or more complex than this one .
the problem appear if we need to do some operation  on the same data items and test results , e.g select the best function it is famous on neural networks , classifier and genetic programing .

for example :
write a C++ or C function which take a function as argument and 2 data items x and y . the argument function either addition or subtraction .

solution :

1-#include
2-using namespace std;

3-int addition (int a, int b)
4-{ return (a+b); }

5-int subtraction (int a, int b)
6-{ return (a-b); }

7-int operation (int x, int y, int (*functocall)(int,int))
8-{
9- int g;
10-  g = (*functocall)(x,y);
11-  return (g);
12-}

13-int main ()
14-{
15-  int m,n;
16-  int (*minus)(int,int) = subtraction;

17-  m = operation (7, 5, addition);
18-  n = operation (20, m, minus);
19-  cout <
20-  return 0;
21- }

in the line no.7 the third parameter for the function operation
int (*functocall)(int,int)

int -> is the return type of the function  .

*functocall->pointer to function .

(int,int)-> the arguments of the function both type int .
in the line no.17 and line no. 18 we call the function and put the name of the two functions addition and minus respectively

by the end of this article i hope you learn new thing .

yours,
Ahmed Ghazey


reference : http://www.cplusplus.com/doc/tutorial/pointers/

Comments

Popular posts from this blog

DevExpress C# Chart Tutorial

Hello , this blog post about Charting in DevExpress , I faced many problems I visited hundreds of pages to solve this problems , actually it was the first time I use DevExpress Charts, Work is not like school or university , in school if you don't know thing you can learn it any time you want , in work you have to do today task yesterday, I like to share my knowledge and skills with you , I hope this Post help you . // clear series on chart  chart.Series.Clear(); // clear Titles of chart chart.Titles.Clear(); // legend alignment  chart.Legend.AlignmentHorizontal = LegendAlignmentHorizontal.Center; chart.Legend.AlignmentVertical = LegendAlignmentVertical.Bottom; chart.Legend.Direction = LegendDirection.LeftToRight; // creating series // series view Type example Line DevExpress.XtraCharts.Series series = new DevExpress.XtraCharts.Series("series name ", ViewType.Line); // add title  DevExpress.XtraCharts.ChartTitle chtTitle = new DevExpress.XtraCharts.Cha...

Recursion

Recursion is a programming technique which function calls itself , this seems strange , however it is one of the most interested and effective technique in programming. it helps you write code in less statements and provides unique conceptual frame work to solve problems. lets discus some problems to know how it works : first example Triangular Numbers : it is series like : 1,3,6,10,15,21........ etc our program should get the nth term in the series, the numbers in this series called triangular numbers due to they can be visualized as a triangle. triangular numbers fig 1 finding the nth term using a loop see this figure : loop adding 1+2+3+4 and so on code is easy  , a loop will add numbers from n to 0 like this int triangle(int n) { int total = 0; while(n > 0) // until n is 1 { total = total + n; // add n (column height) to total --n; // decrement column height } return total; } it easy enough and for sure it is fast . before we start the recu...

LeetCode Problem #19 Remove Nth Node From End of List

Solution for LeetCode Problem #19 Remove Nth Node From End of List it is linked list problem can be solved with multiple solutions, but I'm gonna solve it with fastest solution in java. Problem link we should assign dummy_head it is common while solving linked list problems  Assign 2 iterators slow and fast both equals to dummy_head we don't know the length of the list but we know it is always valid, so we will move with a window of size n+1 when we reach the end by the fast iterator the slow iterator will be in the node n+1 from the last , right? we will assign slow.next to be equal slow.next.next we are dropping the node n from last, got it? we will return dummy_head.next Thank you, AhmedG