Monday, October 6, 2008
What is (DTH)Direct TV Satellite System ?
Are Mutual Funds Risk Free and What are the Advantages?
One must not forget the fundamentals of investment that no investment is insulated from risk. Then it becomes interesting to answer why mutual funds are so popular. To begin with, we can say mutual funds are relatively risk free in the way they invest and manage the funds. The investment from the pool is well diversified across securities and shares from various sectors. The fundamental understanding behind this is not all corporations and sectors fail to perform at a time. And in the event of a security of a corporation or a whole sector doing badly then the possible losses from that would be balanced by the returns from other shares.
This logic has seen the mutual funds to be perceived as risk free investments in the market. Yes, this is not entirely untrue if one takes a look at performances of various mutual funds. This relative freedom from risk is in addition to a couple of advantages mutual funds carry with them. So, if you are a retail investor and planning an investment in securities, you will certainly want to consider the advantages of investing in mutual funds.
- Lowest per unit investment in almost all the cases
- Your investment will be diversified
- Your investment will be managed by professional money managers
How Mutual Funds Work
dubious pointers
C is careful to keep track of the type of each pointer and will not in general allow you to use pointers of different types in the same expression. A pointer to char is a different type of pointer from a pointer to int (say) and you cannot assign one to the other, compare them, substitute one for the other as an argument to a function .... in fact they may even be stored differently in memory and even be of different lengths. Pointers of different types are not the same. There are no implicit conversions from one to the other (unlike the arithmetic types). There are a few occasions when you do want to be able to sidestep some of those restrictions, so what can you do? The solution is to use the special type, introduced for this purpose, of ‘pointer to void’. This is one of the Standard's invented features: before, it was tacitly assumed that ‘pointer to char’ was adequate for the task. This has been a reasonably successful assumption, but was a rather untidy thing to do; the new solution is both safer and less misleading. There isn't any other use for a pointer of that 0 type—void * can't actually point to anything—so it improves readability. A pointer of type void * can have the value of any other pointer assigned to and can, conversely, be assigned to any other pointer. This must be used with great care, because you can end up in some heinous situations. We'll see it being used safely later with the malloc library function. You may also on occasion want a pointer that is guaranteed not to point to any object—the so-called null pointer. It's common practice in C to write routines that return pointers. If, for some reason, they can't return a valid pointer (perhaps in case of an error), then they will indicate failure by returning a null pointer instead. An example could be a table lookup routine, which returns a pointer to the object searched for if it is in the table, or a null pointer if it is not. How do you write a null pointer? There are two ways of doing it and both of them are equivalent: either an integral constant with the value of 0 or that value converted to type void * by using a cast. Both versions are called the null pointer constant. If you assign a null pointer constant to any other pointer, or compare it for equality with any other pointer, then it is first converted the type of that other pointer (neatly solving any problems about type compatibility) and will not appear to have a value that is equal to a pointer to any object in the program. The only values that can be assigned to pointers apart from 0 are the values of other pointers of the same type. However, one of the things that makes C a useful replacement for assembly language is that it allows you to do the sort of things that most other languages prevent. Try this: int *ip; ip = (int *)6; *ip = 0xFF; What does that do? The pointer has been initialized to the value of 6 (notice the cast to turn an integer 6 into a pointer). This is a highly machine-specific operation, and the bit pattern that ends up in the pointer is quite possibly nothing like the machine representation of 6. After the initialization, hexadecimal FF is written into wherever the pointer is pointing. The int at location 6 has had0xFF written into it—subject to whatever ‘location 6’ means on this particular machine. It may or may not make sense to do that sort of thing; C gives you the power to express it, it's up to you to get it right. As always, it's possible to do things like this by accident, too, and to be very surprised by the results.
void, null and dubious pointers
C is careful to keep track of the type of each pointer and will not in general allow you to use pointers of different types in the same expression. A pointer to char is a different type of pointer from a pointer to int (say) and you cannot assign one to the other, compare them, substitute one for the other as an argument to a function .... in fact they may even be stored differently in memory and even be of different lengths. Pointers of different types are not the same. There are no implicit conversions from one to the other (unlike the arithmetic types). There are a few occasions when you do want to be able to sidestep some of those restrictions, so what can you do? The solution is to use the special type, introduced for this purpose, of ‘pointer to void’. This is one of the Standard's invented features: before, it was tacitly assumed that ‘pointer to char’ was adequate for the task. This has been a reasonably successful assumption, but was a rather untidy thing to do; the new solution is both safer and less misleading. There isn't any other use for a pointer of that type—void * can't actually point to anything—so it improves readability. A pointer of type void * can have the value of any other pointer assigned to and can, conversely, be assigned to any other pointer. This must be used with great care, because you can end up in some heinous situations. We'll see it being used safely later with the malloc library function. You may also on occasion want a pointer that is guaranteed not to point to any object—the so-called null pointer. It's common practice in C to write routines that return pointers. If, for some reason, they can't return a valid pointer (perhaps in case of an error), then they will indicate failure by returning a null pointer instead. An example could be a table lookup routine, which returns a pointer to the object searched for if it is in the table, or a null pointer if it is not. How do you write a null pointer? There are two ways of doing it and both of them are equivalent: either an integral constant with the value of 0 or that value converted to type void * by using a cast. Both versions are called the null pointer constant. If you assign a null pointer constant to any other pointer, or compare it for equality with any other pointer, then it is first converted the type of that other pointer (neatly solving any problems about type compatibility) and will not appear to have a value that is equal to a pointer to any object in the program. The only values that can be assigned to pointers apart from 0 are the values of other pointers of the same type. However, one of the things that makes C a useful replacement for assembly language is that it allows you to do the sort of things that most other languages prevent. Try this: int *ip; ip = (int *)6; *ip = 0xFF; What does that do? The pointer has been initialized to the value of 6 (notice the cast to turn an integer 6 into a pointer). This is a highly machine-specific operation, and the bit pattern that ends up in the pointer is quite possibly nothing like the machine representation of 6. After the initialization, hexadecimal FF is written into wherever the pointer is pointing. The int at location 6 has had0xFF written into it—subject to whatever ‘location 6’ means on this particular machine. It may or may not make sense to do that sort of thing; C gives you the power to express it, it's up to you to get it right. As always, it's possible to do things like this by accident, too, and to be very surprised by the results.
Combination of Arrays and pointers
Array elements are just like other variables: they have addresses. int ar[20], *ip; ip = &ar[5]; *ip = 0; /* equivalent to ar[5] = 0; */ The address of ar[5] is put into ip, then the place pointed to has zero assigned to it. By itself, this isn't particularly exciting. What isinteresting is the way that pointer arithmetic works. Although it's simple, it's one of the cornerstones of C. Adding an integral value to a pointer results in another pointer of the same type. Adding n gives a pointer which points n elements further along an array than the original pointer did. (Since n can be negative, subtraction is obviously possible too.) In the example above, a statement of the form *(ip+1) = 0; would set ar[6] to zero, and so on. Again, this is not obviously any improvement on ‘ordinary’ ways of accessing an array, but the following is. int ar[20], *ip; for(ip = &ar[0]; ip < &ar[20]; ip++) *ip = 0; That example is a classic fragment of C. A pointer is set to point to the start of an array, then, while it still points inside the array, array elements are accessed one by one, the pointer incrementing between each one. The Standard endorses existing practice by guaranteeing that it's permissible to use the address of ar[20] even though no such element exists. This allows you to use it for checks in loops like the one above. The guarantee only extends to one element beyond the end of an array and no further. Why is the example better than indexing? Well, most arrays are accessed sequentially. Very few programming examples actually make use of the ‘random access’ feature of arrays. If you do just want sequential access, using a pointer can give a worthwhile improvement in speed. In terms of the underlying address arithmetic, on most architectures it takes one multiplication and one addition to access a one-dimensional array through a subscript. Pointers require no arithmetic at all—they nearly always hold the store address of the object that they refer to. In the example above, the only arithmetic that has to be done is in the for loop, where one comparison and one addition are done each time round the loop. The equivalent, using indexes, would be this: int ar[20], i; for(i = 0; i <> The same amount of arithmetic occurs in the loop statement, but an extra address calculation has to be performed for every array access. Efficiency is not normally an important issue, but here it can be. Loops often get traversed a substantial number of times, and every microsecond saved in a big loop can matter. It isn't always easy for even a smart compiler to recognize that this is the sort of code that could be ‘pointerized’ behind the scenes, and to convert from indexing (what the programmer wrote) to actually use a pointer in the generated code. If you have found things easy so far, read on. If not, it's a good idea to skiped. What follows, while interesting, isn't essential. It has been known to frighten even experienced C programmers. To be honest, C doesn't really ‘understand’ array indexing, except in declarations. As far as the compiler is concerned, an expression like x[n] is translated into *(x+n) and use made of the fact that an array name is converted into a pointer to the array's first element whenever the name occurs in an expression. That's why, amongst other things, array elements count from zero: if x is an array name, then in an expression, x is equivalent to &x[0], i.e. a pointer to the first element of the array. So, since *(&x[0]) uses the pointer to get to x[0], *(&x[0] + 5) is the same as *(x + 5) which is the same as x[5]. A curiosity springs out of all this. If x[5] is translated into *(x + 5), and the expression x + 5 gives the same result as 5 + x (it does), then 5[x] should give the identical result to x[5]! If you don't believe that, here is a program that compiles and runs successfully: #include #include #define ARSZ 20 main(){ int ar[ARSZ], i; for(i = 0; i < now =" %d\n">
How to Declare pointers ?
just like other variables, you have to declare pointers before you can use them. Pointer declarations look much like other declarations: but don't be misled. When pointers are declared, the keyword at the beginning (c int, char and so on) declares the type of variable that the pointer will point to. The pointer itself is not of that type, it is of type pointer to that type. A given pointer only points to one particular type, not to all possible types. Here's the declaration of an array and a pointer: int ar[5], *ip; We now have an array and a pointer (see Figure): An array and a pointer The * in front of ip in the declaration shows that it is a pointer, not an ordinary variable. It is of type pointer to int, and can only be used to refer to variables of type int. It's still uninitialized, so to do anything useful with it, it has to be made to point to something. You can't just stick some integer value into it, because integer values have the type int, not pointer to int, which is what we want. (In any case, what would it mean if this fragment were valid: ip = 6; What would ip be pointing to? In fact it could be construed to have a number of meanings, but the simple fact is that, in C, that sort of thing is just wrong.) Here is the right way to initialize a pointer: int ar[5], *ip;ip = &ar[3]; In that example, the pointer is made to point to the member of the array ar whose index is 3, i.e. the fourth member. This is important. You can assign values to pointers just like ordinary variables; the difference is simply in what the value means. The values of the variables that we have now are shown in Figure 5.4 (?? means uninitialized). Figure Array and initialized pointer You can see that the variable ip has the value of the expression &ar[3]. The arrow indicates that, when used as a pointer, ip points to the variable ar[3]. What is this new unary &? It is usually described as the ‘address-of’ operator, since on many systems the pointer will hold the store address of the thing that it points to. If you understand what addresses are, then you will probably have more trouble than those who don't: thinking about pointers as if they were addresses generally leads to grief. What seems a perfectly reasonable address manipulation on processor X can almost always be shown to be impossible on manufacturer Y's washing machine controller which uses 17-bit addressing when it's on the spin cycle, and reverses the order of odd and even bits when it's out of bleach. (Admittedly, it's unlikely that anyone could get C to work an an architecture like that. But you should see some of the ones it does work on; they aren't much better.) We will continue to use the term ‘address of’ though, because to invent a different one would be even worse. Applying the & operator to an operand returns a pointer to the operand: int i; float f; /* '&i' would be of type pointer to int */ /* '&f' would be of type pointer to float */ In each case the pointer would point to the object named in the expression. A pointer is only useful if there's some way of getting at the thing that it points to; C uses the unary * operator for this job. If p is of type ‘pointer to something’, then *p refers to the thing that is being pointed to. For example, to access the variable x via the pointer p, this would work: #include #include main(){ int x, *p; p = &x; /* initialise pointer */ *p = 0; /* set x to zero */ printf("x is %d\n", x); printf("*p is %d\n", *p); *p += 1; /* increment what p points to */ printf("x is %d\n", x); (*p)++; /* increment what p points to */ printf("x is %d\n", x); exit(EXIT_SUCCESS); } Example You might be interested to note that, since & takes the address of an object, returning a pointer to it, and since * means ‘the thing pointed to by the pointer’, the & and * in the combination *& effectively cancel each other out. (But be careful. Some things, constants for example, don't have addresses and the & operator cannot be applied to them; &1.5 is not a pointer to anything, it's an error.) It's also interesting to see that C is one of the few languages that allows an expression on the left-hand side of an assignment operator. Look back at the example: the expression *p occurs twice in that position, and then the amazing (*p)++; statement. That last one is a great puzzle to most beginners—even if you've managed to wrap your mind around the concept that *p = 0 writes zero into the thing pointed to by p, and that *p += 1 adds one to where p points, it still seems a bit much to apply the ++ operator to *p. The precedence of (*p)++ deserves some thought. It will be given more later, but for the moment let's work out what happens. The brackets ensure that the * applies to p, so what we have is ‘post-increment the thing pointed to by p’. Looking at Table 2.9, it turns out that ++ and * have equal precedence, but they associate right to left; in other words, without the brackets, the implied operation would have been *(p++), whatever that would mean. Later on you'll be more used to it—for the moment, we'll be careful with brackets to show the way that those expressions work. So, provided that a pointer holds the address of something, the notation *pointer is equivalent to giving the name of the something directly. What benefit do we get from all this? Well, straight away it gets round the call-by-value restriction of functions. Imagine a function that has to return, say, two integers representing a month and a day within that month. The function has some (unspecified) way of determining these values; the hard thing to do is to return two separate values. Here's a skeleton of the way that it can be done: #include #include void date(int *, int *); /* declare the function */ main(){ int month, day; date (&day, &month); printf("day is %d, month is %d\n", day, month); exit(EXIT_SUCCESS); } void date(int *day_p, int *month_p){ int day_ret, month_ret; /* * At this point, calculate the day and month * values in day_ret and month_ret respectively. */ *day_p = day_ret; *month_p = month_ret; } Example Notice carefully the advance declaration of date showing that it takes two arguments of type ‘pointer to int’. It returns void, because the values are passed back via the pointers, not the usual return value. The main function passes pointers as arguments to date, which first uses the internal variables day_ret and month_ret for its calculations, then takes those values and assigns them to the places pointed to by its arguments. When date is called, the situation looks like Figure Just as date is called The arguments have been passed to date, but in main, day and month are uninitialized. When date reaches the return statement, the situation is as shown in Figure (assuming that the values for day and month are 12 and 5 respectively). Figure 5.6. Just as date is about to return One of the great benefits introduced by the new Standard is that it allows the types of the arguments to date to be declared in advance. A great favourite (and disastrous) mistake in C is to forget that a function expects pointers as its arguments, and to pass something else instead. Imagine what would have happened if the call of date above had read date(day, month); and no previous declaration of date had been visible. The compiler would not have known that date expects pointers as arguments, so it would pass the int values of day and month as the arguments. On a large number of computers, pointers and integers can be passed in the same way, so the function would execute, then pass back its return values by putting them into wherever day and monthwould point if their contents were pointers. This is very unlikely to give any sensible results, and in general causes unexpected corruption of data elsewhere in the computer's store. It can be extremely hard to track down! Fortunately, by declaring date in advance, the compiler has enough information to warn that a mistake has almost certainly been made. Perhaps surprisingly, it isn't all that common to see pointers used to give this call-by-reference functionality. In the majority of cases, call-by-value and a single return value are adequate. What is much more common is to use pointers to ‘walk’ along arrays.
What is Pointers ?
Friday, October 3, 2008
C language Pointer arithmetic
#include #include #define ARSZ 10 main(){ float fa[ARSZ], *fp1, *fp2; fp1 = fp2 = fa; /* address of first element */ while(fp2 != &fa[ARSZ]){ printf("Difference: %d\n", (int)(fp2-fp1)); fp2++; } exit(EXIT_SUCCESS); }The pointer fp2 is stepped along the array, and the difference between its current and original values is printed. To make sure thatprintf isn't handed the wrong type of argument, the difference between the two pointers is forced to be of type int by using the cast(int). That allows for machines where the difference between two pointers is specified to be long. Unfortunately, if the difference does happen to be long and the array is enormous, the last example may give the wrong answers. This is a safe version, using a cast to force a long value to be passed:
#include #define ARSZ 10 main(){ float fa[ARSZ], *fp1, *fp2; fp1 = fp2 = fa; /* address of first element */ while(fp2 != &fa[ARSZ]){ printf("Difference: %ld\n", (long)(fp2-fp1)); fp2++; } return(0); }
Information about of How Mutual Funds Work
Mutual funds can be either or both of open ended and closed ended investment companies depending on their fund management pattern. An open-end fund offers to sell its shares (units) continuously to investors either in retail or in bulk without a limit on the number as opposed to a closed-end fund. Closed end funds have limited number of shares.
Mutual funds have diversified investments spread in calculated proportions amongst securities of various economic sectors. Mutual funds get their earnings in two ways. First is the most organic way, which is the dividend they get on the securities they hold. Second is by the redemption of their shares by investors will be at a discount to the current NAVs (net asset values).
What Is A Mutual Fund
Use of jsp scriptlet to index jsp array variable in struts
For that first we have to declare the array variable in the java form bean with its getters and setters as given below.
int[]chkvalue=new int[20];
public int[] getChkvalue() {
return chkvalue;
}
public void setChkvalue(int[] chkvalue) {
this.chkvalue = chkvalue;
}
Now we can index the element using scriptlet as given below in the jsp page.
Note: Please careful about the quotes
<logic:present name="list">
<logic:iterate id="id" name="list" indexId="ctr">
<html:checkbox name="id" value="" property='<%="chkvalue["+ ctr+"]"%>'>
</html:checkbox>
</logic:iterate>
</logic:present>
Use of logic:iterate within table
<table>
<logic:present name="names">
<logic:iterate id="id" name="names" indexId="ctr">
<TR>
<TD >
<bean:write name="id" property="rollNumber" /></TD>
<TD>
<bean:write name="id" property="studentName" />
</TD>
</tr>
</logic:iterate>
</logic:present>
</table>
Using for loop a method returning arraylist in java struts using jdbc
Here is the sample method is given which is retuning the database values with the arraylist in which the for loop is used to execute the query multiple time.
public ArrayList
ArrayList
MYSQLConnect connect=new MYSQLConnect();
Connection conn = connect.connection;
Statement smt = conn.createStatement();
ResultSet rs = null;
//write select query for checking password
for(int i=0;i
{
String query="select SUM(attendance) As presenty,count(attendance)as
total,SUM(attendance)/count(attendance)*100 as percentage
from attendance where gr_number='"+grNumber[i]+"' and (Date
between '"+datefrom+"' and '"+dateto+"') order by `date` ";
rs=smt.executeQuery(query);
while(rs.next()== true){
StudentDetailsForm form =new StudentDetailsForm();
form.setPresentdays(rs.getInt("presenty"));
form.setTotaldays(rs.getInt("total"));
form.setAverage(rs.getInt("percentage"));
System.out.println(rs.getInt("percentage"));
list.add(form);
}
}
smt.close();
rs.close();
conn.close();
return list;
}
Inserting database values into the String array in java struts using jdbc
Here is the sample method code is given which is inserting the database values in String array variable.
public String[] findGRNumbers(String branch,String course,String trimester,int size) throws DataAccessException,java.sql.SQLException{
MYSQLConnect connect=new MYSQLConnect();
Connection conn = connect.connection;
Statement smt = conn.createStatement();
ResultSet rs;
int no=0;
String[]str=new String[size];
//write select query for checking password
String query="select gr_number,roll_number,student_name from
student_master where branch='"+branch+"' and
course='"+course+"' and trimester='"+trimester+"'";
rs=smt.executeQuery(query);
while(rs.next()== true){
str[no]=rs.getString("gr_number");
no++;
}
smt.close();
rs.close();
conn.close();
return str;
}
Making a method returning arraylist in java Struts using jdbc
Here is the sample method is given which is retuning the database values with the arraylist.
public ArrayList
ArrayList
MYSQLConnect connect=new MYSQLConnect();
Connection conn = connect.connection;
Statement smt = conn.createStatement();
ResultSet rs;
//int no=0;
//String[]str=new String[20];
//write select query for checking password
String query="select DISTINCT `date` from attendance where (Date between
'"+datefrom+"' and '"+dateto+"')";
rs=smt.executeQuery(query);
while(rs.next()== true){
StudentDetailsForm form =new StudentDetailsForm();
form.setDateFrom(rs.getString("date"));
list1.add(form);
}
smt.close();
rs.close();
conn.close();
return list1;
}