Sunday, 29 June 2014
Tuesday, 24 June 2014
When to use abstract class?
What is abstract class?
Abstract class is a special type
of class which cannot be instantiated and acts as a base class for other
classes. Abstract class members marked as abstract must be implemented by
derived classes.
When to use abstract class?
The purpose of an abstract class
is to provide basic or default functionality as well as common functionality
that multiple derived classes can share and override.
How toCreate use abstract class?
public abstract class AbsAcType
{
public int ACno { get; set; }
public String ACFirstName { get; set; }
public String ACLastName { get; set; }
public decimal Amount { get; set; }
public decimal InterestRate { get; set; }
public string CustomerName()
{
return ACFirstName + "
" + ACLastName;
}
public string AcountNo(string BankName)
{
return BankName + ACno;
}
public abstract decimal AcBalance();
}
public class SavingAC : AbsAcType
{
public override decimal AcBalance()
{
return Amount + InterestRate*(decimal)0.20;
}
}
public class currentAC : AbsAcType
{
public override decimal AcBalance()
{
return Amount + InterestRate * (decimal)0.028;
}
}
protected void btnSavingAC_Click(object sender, EventArgs e)
{
decimal amount,interestRate;
decimal.TryParse(txtAmount.Text,out amount);
decimal.TryParse(txtInterestRate.Text,out interestRate);
string firstName = txtFirstName.Text, lastName =
txtLastName.Text;
AbsAcType objSaving = new SavingAC()
{
ACno= 101,
ACFirstName = firstName,
ACLastName = lastName,
Amount=amount,
InterestRate=interestRate
};
lblAcNo.Text = objSaving.AcountNo("CITI");
lblFullname.Text=
objSaving.CustomerName();
lblResBal.Text = objSaving.AcBalance().ToString();
}
protected void btncurrentAC_Click(object sender, EventArgs e)
{
decimal amount, interestRate;
decimal.TryParse(txtAmount.Text, out amount);
decimal.TryParse(txtInterestRate.Text, out interestRate);
string firstName = txtFirstName.Text, lastName =
txtLastName.Text;
AbsAcType objcurrent = new currentAC()
{
ACno = 101,
ACFirstName = firstName,
ACLastName = lastName,
Amount = amount,
InterestRate = interestRate
};
lblAcNo.Text = objcurrent.AcountNo("CITI");
lblFullname.Text =
objcurrent.CustomerName();
lblResBal.Text =
objcurrent.AcBalance().ToString();
}
Labels:
OOPs
Monday, 16 June 2014
ASP.NET Page Output Cache
ASP.NET Caching is used to build high-performance, scalable ASP.NET web applications by storing responses in memory. On subsequent requests, the page code is not executed and the cached output is used to serve the request.
By default, when we request an ASP.NET website, every request is processed by many stages, such as Page initialization, Load, Rendering, etc. This consumes a lot of resources on the server. Consider the following scenario: many customers browse ASP.NET websites for a news page and the news page won’t change for several hours. Based on a common route, when multiple customers request the same news page at almost the same time, ASP.NET will execute the same code to generate the response with the same news multiple times. This is a resource wasting process. Hence, we start thinking whether we can generate the response once and serve multiple customers with it. The answer is Cache.
Output Cache has the advantage of being simple to implement, and is sufficient in most cases. It simply keeps a copy of the response that was sent to the client in memory and subsequent requests are then responded with the cached output until the cache expires, which incredibly improves the ASP.NET web application performance.
For ASP.NET Output Cache, ASP.NET uses
@ OutputCache
to declare many attributes to control the output caching policies of the ASP.NET page or a user control contained in a page.- Drag and drop a
DropDownList
in the page and add three items to it. - Add
@OutputCache
in the ASPX markup and specify the expiration time andVaryByControl
attribute. For example:OutputCache Duration="100" VaryByControl="ddlitemselection"
. - Run the ASP.NET web application and launch this page, we can see that the different items have their corresponding cache.
Sample Code:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="JScript.aspx.cs" Inherits="Javascript.JScript" %>
<%@ OutputCache Duration="100" VaryByParam="ddlitemselection" %>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
<title>My Page</title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js" type="text/javascript"></script>
<script type="text/javascript">
function Test() {
alert("hi");
$("#trOpen").show();
}
function AnotherFunction() {
alert("This
is another function");
}
$(document).ready(function () {
$(".TestStyle").click(function () {
alert("Welcome");
});
});
</script>
<style>
.TestStyle {
font: 12pt verdana;
font-weight: 700;
color: orange;
}
.TestStyle1 {
font: 12pt verdana;
font-weight: 800;
color: red;
}
</style>
</head>
<body>
<form id="form2" runat="server">
<table>
<tr><td>
<asp:RadioButtonList ID="rbtntest" runat="server" onchange="Test()">
<asp:ListItem>ram</asp:ListItem>
<asp:ListItem>Sri</asp:ListItem>
<asp:ListItem>Sriram</asp:ListItem>
</asp:RadioButtonList>
</td>
</tr>
<tr id="trOpen"style="display:none">
<td>
<asp:Button ID="MyButton" runat="server" Text="Ok" OnClick="MyButton_Click" />
</td>
</tr>
<tr><td>
<asp:Button ID="Button1" runat="server" CssClass="TestStyle" Text="Click me" />
<asp:Button ID="Button2" runat="server" CssClass="TestStyle" Text="Touch me" />
</td></tr>
<tr><td>
<asp:DropDownList ID="ddlitemselection" runat="server" AutoPostBack="True" OnSelectedIndexChanged="ddlitemselection_SelectedIndexChanged"></asp:DropDownList></td></tr>
<tr><td>
<asp:GridView ID="grd" runat="server"></asp:GridView>
</td></tr>
</table>
</form>
</body>
</html>
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace Javascript
{
public partial class JScript : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
DataTable t = new DataTable();
string conn = ConfigurationManager.ConnectionStrings["conn"].ConnectionString;
using (SqlConnection con = new SqlConnection(conn))
{
con.Open();
using (SqlDataAdapter a = new SqlDataAdapter("SELECT * FROM SampleTable", con))
a.Fill(t);
}
grd.DataSource = t;
grd.DataBind();
ddlitemselection.Items.Add("Madurai");
ddlitemselection.Items.Add("Sivakasi");
ddlitemselection.Items.Add("Sirukkulam");
ddlitemselection.Items.Add("Channai");
ddlitemselection.Items.Add("Nellai");
ddlitemselection.DataBind();
}
}
protected void MyButton_Click(object sender, EventArgs e)
{
Page.ClientScript.RegisterStartupScript(this.GetType(), "myScript", "AnotherFunction();", true);
}
protected void ddlitemselection_SelectedIndexChanged(object sender, EventArgs e)
{
DataTable t = new DataTable();
string conn = ConfigurationManager.ConnectionStrings["conn"].ConnectionString;
using (SqlConnection con = new SqlConnection(conn))
{
con.Open();
using (SqlDataAdapter a = new SqlDataAdapter("SELECT * FROM
[SampleDB].[dbo].[SampleTable] where Address='" + ddlitemselection.SelectedItem.Text+"'", con))
a.Fill(t);
}
grd.DataSource = t;
grd.DataBind();
}
}
}
Subscribe to:
Posts (Atom)