当前位置:
首页 > 编程开发 > Objective-C编程 >
-
c#语法学习泛型gereric
制作者:剑锋冷月 单位:无忧统计网,www.51stat.net
/*
*CreatedbySharpDevelop.
*User:Administrator
*Date:2008/9/4
*Time:上午10:40
*泛型(gereric)
*/
usingSystem;
classStack
{
privateint[]items;
privateintcount;
publicStack(intsize)
{
items=newint[size];
count=0;
}
publicvoidPush(intx)
{
items[count++]=x;//這時是先賦值再進行自加咚?lt;br /> }
publicintPop()
{
returnitems[--count];//先自減再返回值
}
}
classTest
{
staticvoidMain()
{
Stacks=newStack(10);
s.Push(111);//先壓入111
s.Push(222);//再壓入222
Console.WriteLine(s.Pop().ToString());
Console.WriteLine(s.Pop().ToString());
/*
*輸出結果為
*222
*111
*這個程序演示了棧(Stack)的先進後出的原理
*/
}
}
/*
*CreatedbySharpDevelop.
*User:Administrator
*Date:2008/9/4
*Time:上午10:40
*泛型(gereric)
*現在需要改變我們希望可以傳入float類型的數據
*因此我們使用了弱類型的object,這時候我們傳入
*的參數就可以是整行和其它類型的數據.
*
*因為需要經過四次裝箱和拆箱操作,性能也就不是很好.
*當然是說大量的數據情況下
*/
usingSystem;
classStack
{
privateobject[]items;
privateintcount;
publicStack(intsize)
{
items=newobject[size];
count=0;
}
publicvoidPush(objectx)
{
items[count++]=x;//這時是先賦值再進行自加咚?lt;br /> }
publicobjectPop()
{
returnitems[--count];//先自減再返回值
}
}
classTest
{
staticvoidMain()
{
Stacks=newStack(10);
s.Push(111.1);//裝箱
s.Push(222.2);//裝箱
Console.WriteLine((double)s.Pop()+(double)s.Pop());//兩次折箱
}
}
/*
*CreatedbySharpDevelop.
*User:Administrator
*Date:2008/9/4
*Time:上午11:01*泛型(gereric)
*解決了性能上的問題,同時寫程序也會覺的更方便
*它引進行了一個類型參數
*/
usingSystem;
classStack<T>//聲明泛型
{
privateT[]items;
privateintcount;
publicStack(intsize)
{
items=newT[size];
count=0;
}
publicvoidPush(Tx)
{
items[count++]=x;//這時是先賦值再進行自加咚?lt;br /> }
publicTPop()
{
returnitems[--count];//先自減再返回值
}
}
classTest
{
staticvoidMain()
{
Stack<int>s=newStack<int>(10);
s.Push(111);
s.Push(222);
Console.WriteLine(s.Pop()+s.Pop());
}
}
/*上面使用了泛型,這樣提高了程序的性能,不再需要進行裝箱和拆箱的動作
*
*如果我們現在需要使用小數只需要把泛型的類型參數改為double就可以了.
*
*
**/
/*
*CreatedbySharpDevelop.
*User:Administrator
*Date:2008/9/5
*Time:上午11:32
*兩個泛型參數的例子,通常用<T,S>
*/
usingSystem;
publicclassStu<T,S>
{
privateTname;
privateSage;
publicStu(TName,SAge)
{
this.name=Name;
this.age=Age;
}
publicvoidShow()
{
Console.WriteLine("姓名是:{0},年齡:{1}",name,age);
}
}
classTest
{
staticvoidMain()
{
Stu<string,int>t=newStu<string,int>("Athrun",26);
t.Show();
}
}
/*
*CreatedbySharpDevelop.
*User:Administrator
*Date:2008/9/4
*Time:上午10:40
*泛型(gereric)
*/
usingSystem;
classStack
{
privateint[]items;
privateintcount;
publicStack(intsize)
{
items=newint[size];
count=0;
}
publicvoidPush(intx)
{
items[count++]=x;//這時是先賦值再進行自加咚?lt;br /> }
publicintPop()
{
returnitems[--count];//先自減再返回值
}
}
classTest
{
staticvoidMain()
{
Stacks=newStack(10);
s.Push(111);//先壓入111
s.Push(222);//再壓入222
Console.WriteLine(s.Pop().ToString());
Console.WriteLine(s.Pop().ToString());
/*
*輸出結果為
*222
*111
*這個程序演示了棧(Stack)的先進後出的原理
*/
}
}
/*
*CreatedbySharpDevelop.
*User:Administrator
*Date:2008/9/4
*Time:上午10:40
*泛型(gereric)
*現在需要改變我們希望可以傳入float類型的數據
*因此我們使用了弱類型的object,這時候我們傳入
*的參數就可以是整行和其它類型的數據.
*
*因為需要經過四次裝箱和拆箱操作,性能也就不是很好.
*當然是說大量的數據情況下
*/
usingSystem;
classStack
{
privateobject[]items;
privateintcount;
publicStack(intsize)
{
items=newobject[size];
count=0;
}
publicvoidPush(objectx)
{
items[count++]=x;//這時是先賦值再進行自加咚?lt;br /> }
publicobjectPop()
{
returnitems[--count];//先自減再返回值
}
}
classTest
{
staticvoidMain()
{
Stacks=newStack(10);
s.Push(111.1);//裝箱
s.Push(222.2);//裝箱
Console.WriteLine((double)s.Pop()+(double)s.Pop());//兩次折箱
}
}
/*
*CreatedbySharpDevelop.
*User:Administrator
*Date:2008/9/4
*Time:上午11:01*泛型(gereric)
*解決了性能上的問題,同時寫程序也會覺的更方便
*它引進行了一個類型參數
*/
usingSystem;
classStack<T>//聲明泛型
{
privateT[]items;
privateintcount;
publicStack(intsize)
{
items=newT[size];
count=0;
}
publicvoidPush(Tx)
{
items[count++]=x;//這時是先賦值再進行自加咚?lt;br /> }
publicTPop()
{
returnitems[--count];//先自減再返回值
}
}
classTest
{
staticvoidMain()
{
Stack<int>s=newStack<int>(10);
s.Push(111);
s.Push(222);
Console.WriteLine(s.Pop()+s.Pop());
}
}
/*上面使用了泛型,這樣提高了程序的性能,不再需要進行裝箱和拆箱的動作
*
*如果我們現在需要使用小數只需要把泛型的類型參數改為double就可以了.
*
*
**/
/*
*CreatedbySharpDevelop.
*User:Administrator
*Date:2008/9/5
*Time:上午11:32
*兩個泛型參數的例子,通常用<T,S>
*/
usingSystem;
publicclassStu<T,S>
{
privateTname;
privateSage;
publicStu(TName,SAge)
{
this.name=Name;
this.age=Age;
}
publicvoidShow()
{
Console.WriteLine("姓名是:{0},年齡:{1}",name,age);
}
}
classTest
{
staticvoidMain()
{
Stu<string,int>t=newStu<string,int>("Athrun",26);
t.Show();
}
}
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数