Thursday, April 4, 2019
Advantages And Disadvantages Of Using A Pointer Computer Science Essay
Advantages And Disadvantages Of Using A Pointer Computer Science EssayWrite advantages and disadvantages of using arrow. How the concept of cursors is useful in the executing of entropy structures?A pointer in allows a hunt down or a weapons platform to access a variable outside the preview intimacy or a program ,using pointer program preempt access any entrepot location in the computers retentiveness.2)since using return statement a function can only pass back a single value to the calling function, pointers allows a function to pass back more than unitary value by writing them into retrospect locations that are hearty to calling function.3)Use of pointer increases makes the program execution of instrument faster4)using pointers, starts and structures can be progressled in more businesslike federal agency.5) without pointers it will be impossible to create complex data structures such as linked constitute , trees, and graphs.Disadvantages of pointers-1)we can ac cess the restricted storage area.2) Pointers require wiz additional dereference, meaning that the final formula must read the variables pointer from memory, then read the variable from the pointed-to memory. This is slower than reading the value forthwith from memory.3). If sufficient memory is not purchasable during runtime for the storage of pointers, the program may crashWhen setting updata ststructureslikelists,queuesand trees, it is necessary to keep pointers to help manage how the structure is put throughed and controlled.Pointers and Structures can be used to build data structures that expand and shrink during execution examples stack queues,trees etc.While pointer has been used to enclose the wrap up of a variable,it more properly applies to data structures whose interface explicitly allows the pointer to be manipulated as a memory address.Because pointers allow largely unprotected access to memory addresses.2). Elaborate the concept of fit(p) squeeze storage allo cation and Buddy schema in dynamic memory counsel.Sol.Fixed regular hexahedron storage allocation- This is the simplest storage maintenance method. Here distributively gag rule is of the same surface. The size is indomitable by the system manager. Here the memory manager maintain a pointer AVAIL which points a list of non contiguous memory blocks.A user program communicate with the memory manager by delegacy of two function GETNODE(NODE) and RETURNNODE(PTR).The procedure GETNODE is to get a memory block to store data of type NODE. This procedure when invoked by a program returns a pointer to initial block in the pool of restorage. The AVAIL then points to the next block.If avail= nought it indicates no more memory is available for allocation. Similarly whenever a memory block is no more essential it can be returned to the memory verify through a procedure RETURN NODE().Buddy system- It is the another storage management system which restricts the size of blocks to some located set of sizes. These blocks of restricted sizes are maintained in a linked list. Whenever a request for a block of size N comes, the number M the smallest of the fixed sizes but equal to or largest than N, is determined and a block of size M is allocated if available on the list. If not available then a larger block if available is split into two sub-blocks cognize a s buddies. Each of them are also of fixed sizes and the process is repeated until a block of size M is produced. for example , if k=1 and Fo=8, then the block sizes are 8,16,32,64,128,. THAT is ,the block sizes are successive powers of 2 and the buddy system based on such fixed sizes is called binary buddy system.3.)Differentiate between static memory allocation and dynamic memory allocation. Illustrate various memory management functionsSol.In case of static storage management scheme , the net amount of memory required for various data for a program is allocated before the start of the execution of a program once memory is allocated, it neither can be extended nor can be returned to the memory bank for the use of other programs at the same time. On the other hand dynamic storage management schemes allows user to allocate and deallocate as per necessity during the execution of programs.The static storage allocation is easy to implement and efficient from execution point of view .Here all variables those are required for a program is allocated during stash time this is why static storage allocation is a compile time phenomena. In this each subprogram/subroutine of a program is compiled separately and the space required for them is reserved till the execution of the program. On the other hand dynamic memory allocation , space for memory variables is allocated dynamically that is as per the current demand during the execution. When a subprogram is invoked space for it is allocated and space is returned when the subprogram completes its execution. Thus , the space required to run a program is not fixed as in static allocation, rather it varies as program execute.Various memory management functions-1)malloc()-The malloc function dynamically allocates memory from heap.The prototype for malloc() function is discharge *malloc(size_t size)2)calloc()- The calloc() function dynamically allocates memory automatically initializes the memory to zeroes. The prototype for calloc() function isVoid *calloc(size_t nitems , size_t size)It takes two arguments . The get-go argument is the number of instalments and the second argument is the size of each agent.3) realloc()- The realloc() function changes the size of previously dynamically allocated memory with malloc(), calloc(), realloc() functions.The prototype for realloc() function isVoid *realloc(void *block, size_t size)It takes two argument . the first argument is the pointer to the master copy object and the second argument is the new size of the object.4.)Write different ways to manage records in memorySol.) Since records may contain non homogeneous data, the elements of a record cannot be stored in an array . Some programing languages such as PASCAL and COBOL do have record structures built into the language.Suppose a programming language does not have available the hierarchical structures that are available in PASCAL and COBOL . presume the record contains non homogeneous data , the record may have to be stored in individual variables , one for each of its elementary data items. On the other hand one wants to store an entire rouse of records, such a file may be stored in memory as a sight of arrays that is, where elements in different arrays with the same subscript belonging to the same record.Part-B1.)Illustrate the use of array of pointers and pointers to an arraySol.)An array of pointers is that for eg if we have array of 10 int pointers ie int *a10 then each element that which is stored in array are pointed by pointers. here we will have ten pointers. In pointer to an array for eg int(*a)1 0 here all the elements that is all the ten elements are pointed by a single pointer.int *a10-array of pointers.consider one array int b10=1,2,3,4,5,6,7,8,9,0soelements will be stored in addresses .now this address arestored in array of pointers.thatsint *a10=b+0,b+1,b+2,b+3,b+4,b+5,b+6,b+7,b+8,b+9means a+0=address of value 1 is the first element of int*a(first element of int b10)and so on. plot int(*a)10-here a is an pointer to an array containing 10integers.suppose int b10then a=b10this will give element of int b10 array thats b0and so on but in case of two dimensional array first we have to allocate base address of respective one dimensional array and base address of element of one dimensional array then only we can use pointer to an array. discover example to show the use of furthest pointer and interruption pointer problemsSol.)A far pointer uses both the segment and the offset address to point to a location in memory The far pointer can point to any location in memory. . Far pointers have a size of 4 bytes . They store both the segment and the offset of the address the pointer is referencing. A far pointer has an address range of 0 1M bytes. A far pointer can be incremented and or decremented completely the offset of the pointer is actually incremented or decremented. The segment is never incremented by the arithmetic operators.On the other hand Dangling pointers are the pointers that do not point tao a valid object of the appropriate type. These pointers bob up when an object is deleted or deallocated,without modifting the value of the pointer so that pointer stll points to the memory location of deallocated memory .As the system may reallocate the previously freed memory to another process ,if the original program then derefrences the dangling pointer,results in bugs or errors as the memory may contain completely different data.Consider the undermentioned examplechar *cp = NULLchar ccp = &c /* cp is now a dangling pointer */Solution to dangling po interchar *cp = malloc ( A_CONST )free ( cp ) /* cp now becomes a dangling pointer */cp = NULL /* cp is no longer dangling */Differentiate between linked list and arrays in terms of representations, trave and essaying.Sol.)1)In case of array traversing is used visiting all elements in an array while to traverse a single linked list we mean to visit every node in the list starting from first node to last node.2).Searching operation in an array is applied to search an element amour in an array.It is a process of finding the location of given element in an array.The search is state to be successful if the given element is found.there are two types of search operation Linear searchBinary searchIf the array elements are in random order then one have to use linear search technique and if the array elements are sorted then it is preferable to strike binary search technique.While in case of linked list only linear searching is possible.This is one of the limitation of linked lists as th ere is no way to find the location of the middle element of the list.can we perform binary search in linked list ,if no then ornament the reason.Sol.)No, we cannot perform binary search in linked list because there is no wayOf index the middle element in the list. With a sorted linear array we can apply a binary search whose running time is proportional to log2n. On the other hand a binary search algorithm cannot be applied to a sorted linked list, since there is no way of indexing the middle element in the list. This property is one of the main drawbacks in using a linked list as a data structure.
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.