Sponsored Content
Full Discussion: pointer
Top Forums Programming pointer Post 89695 by parasa on Tuesday 15th of November 2005 05:41:31 AM
Old 11-15-2005
Quote:
Originally Posted by sarwan
void main()
{
int a[]={1,2,3,4,5,6,7,8,9,10};

int *p=a;

int *q=&a[9];

cout<<q-p+1<<endl;
}
the output is actually difference between the address locations and in this case the it happens to be 10.
p => address of start of array
q => address of 9th element.

((q-p) + 1) ==> (9 - 0) + 1 ==> 10..

Regards
 

10 More Discussions You Might Find Interesting

1. Programming

why we never delete a pointer twice

can u tell me the reson that why we should not delete a pointer twice.? if we delete ponter twice then what happen and why this happen Regards, Amit (2 Replies)
Discussion started by: amitpansuria
2 Replies

2. Programming

pointer problem

could any one tell why the following is showing segmentation fault while using **ptr but working fine using **a #include<stdio.h> ... (1 Reply)
Discussion started by: useless79
1 Replies

3. Programming

far pointer

what is far pointer in C (1 Reply)
Discussion started by: useless79
1 Replies

4. Programming

Need help in character pointer

Hi, I am trying to divide my input to different type of out puts for some other use. ex: logical_name : jkl00001 expected out put : model=jkl and num=00001 here is the code i actually written /*******************************************************************/ void... (11 Replies)
Discussion started by: jagan_kalluri
11 Replies

5. Programming

pass a pointer-to-pointer, or return a pointer?

If one wants to get a start address of a array or a string or a block of memory via a function, there are at least two methods to achieve it: (1) one is to pass a pointer-to-pointer parameter, like: int my_malloc(int size, char **pmem) { *pmem=(char *)malloc(size); if(*pmem==NULL)... (11 Replies)
Discussion started by: aaronwong
11 Replies

6. Programming

matrix pointer

Can anyone tell me what the following statements do? float (*tab); tab=(float (*)) calloc(MAXCLASS, (MAXCLASS+1)*sizeof(float)); (3 Replies)
Discussion started by: littleboyblu
3 Replies

7. Programming

C dynamic pointer

Hi, Can anyone tell me how i can declare and allocate dynamically an array of pointers to structured type?? Is declaration something like this:? struct_name ** array; (1 Reply)
Discussion started by: littleboyblu
1 Replies

8. Programming

Pointer to pointers

Hi guys, I'm trying to understand pointers in C and made a simple example and I've problems with It. Can someone help? #include <stdio.h> #include <stdlib.h> #include <assert.h> int f1(char **str_); int main(int argc, char **argv) { char *str = NULL; f1(&str); ... (3 Replies)
Discussion started by: pharaoh
3 Replies

9. Programming

Pointer and address

This code is to print out the program name and arguments list one by one: 1 #include<stdio.h> 2 3 void main(int argc, char *argv) 4 { 5 int iCount = 0; 6 while (iCount < argc) { 7 printf("argc:%d\t%s\n",iCount, argv); 8 ... (14 Replies)
Discussion started by: yifangt
14 Replies

10. Programming

Pointer confusion

Here are two programs that pass a pointer to a variable but behave differently. Shouldnt the i in second program be 0 after the function call? #include<stdio.h> void changeI(int *i) { *i = 10; } int main(void) { int i=5; printf("%d before\n", i); changeI(&i); printf("%d... (1 Reply)
Discussion started by: dragonpoint
1 Replies
FBB::Pipe(3bobcat)						   Error handler						FBB::Pipe(3bobcat)

NAME
FBB::Pipe - Defines a system level pipe SYNOPSIS
#include <bobcat/pipe> Linking option: -lbobcat DESCRIPTION
FBB::Pipe objects may be used to construct a pipe. FBB::Pipe objects offer a simple interface to the reading and writing ends of pipes. FBB::Pipe objects are object-wrappers around the pipe(2) system call. NAMESPACE
FBB All constructors, members, operators and manipulators, mentioned in this man-page, are defined in the namespace FBB. INHERITS FROM
- CONSTRUCTORS
o Pipe(): The default Pipe() constructor constructs a basic pipe, calling pipe(2). This constructor throws an Errno exception if the default Pipe constructor did not properly complete. The thrown Errno object's which() member shows the system's errno value set by the failing pipe(2) function. o Pipe(int const *fd): This constructor expects two file descriptors, which already define a pipe, stored at fd. Following the construction of the Pipe object the array at by fd is no longer used by the Pipe object. The copy constructor is available. Note that when the pipe goes out of scope, no close(2) operation is performed on the pipe's ends. If the pipe should be closed by the desc- tructor, derive a class from Pipe(3bobcat), whose destructor performs the required closing-operation. MEMBER FUNCTIONS
o int readFd() const: Returns the pipe's file descriptor that is used for reading o void readFrom(int filedescriptor): Sets up redirection from the internal read filedescriptor to the given filedescriptor: information is read from the FBB::Pipe object when reading from the provided filedescriptor. o void readFrom(int const *filedescriptors, size_t n): Sets up redirection from the internal read filedescriptor to the given filedescriptors: information is read from the FBB::Pipe object when reading from any of the n provided filedescriptors (experimental). o int readOnly(): Closes the writing end of the pipe, returns the reading end's file descriptor. o void verify() const: Obsoleted, will be removed in a future Bobcat release. o int writeFd() const: Returns the pipe's file descriptor that is used for writing o void writtenBy(int filedescriptor): Sets up redirection from the internal write filedescriptor to the given filedescriptor: information is written to the FBB::Pipe object when writing to the provided filedescriptor. o void writtenBy(int const *filedescriptors, size_t n): Sets up redirection from the internal write filedescriptor to the given filedescriptors: information is written to the FBB::Pipe object when writing to each of the n provided filedescriptors. o int writeOnly(): Closes the reading end of the pipe, returns the writing end's file descriptor. PROTECTED ENUMERATION
The RW protected enumeration has the following elements: o READ: The index in d_fd[] (see below) of the element holding the pipe's reading file descriptor; o WRITE: The index in d_fd[] (see below) of the element holding the pipe's writing file descriptor PROTECTED DATA
o int d_fd[2]: The array holding the pipe's file descriptors. The READ element contains the pipe's reading file descriptor, the WRITE element con- tains the pipe's writing file descriptor, EXAMPLE
#include <bobcat/pipe> #include <sys/types.h> #include <sys/wait.h> #include <unistd.h> #include <iostream> #include <string> using namespace std; using namespace FBB; int main() { Pipe p; // construct a pipe cout << "Read file descriptor: " << p.getReadFd() << endl; cout << "Write file descriptor: " << p.getWriteFd() << endl; int pid = fork(); if (pid == -1) return 1; if (!pid) //child { p.readFrom(STDIN_FILENO); // read what goes into the pipe string s; getline(cin, s); cout << "CHILD: Got `" << s << "'" << endl; getline(cin, s); cout << "CHILD: Got `" << s << "'" << endl; return 0; } p.writtenBy(STDOUT_FILENO); // write to the pipe via cout cout << "first line" << endl; cout << "second line" << endl; waitpid(pid, 0, 0); return 0; } FILES
bobcat/pipe - defines the class interface SEE ALSO
bobcat(7), pipe(2), mkfifo(3) BUGS
Note that when the pipe goes out of scope, no close(2) operation is performed on the pipe's ends. If the pipe should be closed by the desc- tructor, derive a class from Pipe(3bobcat), whose destructor performs the required closing-operation. DISTRIBUTION FILES
o bobcat_3.01.00-x.dsc: detached signature; o bobcat_3.01.00-x.tar.gz: source archive; o bobcat_3.01.00-x_i386.changes: change log; o libbobcat1_3.01.00-x_*.deb: debian package holding the libraries; o libbobcat1-dev_3.01.00-x_*.deb: debian package holding the libraries, headers and manual pages; o http://sourceforge.net/projects/bobcat: public archive location; BOBCAT
Bobcat is an acronym of `Brokken's Own Base Classes And Templates'. COPYRIGHT
This is free software, distributed under the terms of the GNU General Public License (GPL). AUTHOR
Frank B. Brokken (f.b.brokken@rug.nl). libbobcat1-dev_3.01.00-x.tar.gz 2005-2012 FBB::Pipe(3bobcat)
All times are GMT -4. The time now is 05:23 AM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy