c#基础知识(一)
上一篇 /
下一篇 2014-04-30 15:13:36
/ 个人分类:C#
c#基础知识(一)
VS常用快捷键
ctrl+shift+F9 取消断点
ctrl+k+c 注释
ctrl+k+u 取消注释
F5运行调试
F10 跨程序执行
F11单步执行
ctrl+r,ctrl+e 生成get与set
for与foreach循环
一般会用for或者foreach对一个数组结构的类进行遍历操作,
public void For()
{
string[] array = new string[]{"111","222","333"};
for(int i = 0; i < array.Length; i++)
{
Console.WriteLine(array[i]);
}
}
////Results :
111
222
333
----------------------------
public void Foreach()
{
string[] array = new string[]{"111","222","333"};
foreach(string s in array)
{
Console.WriteLine(s);
}
}
public class 与 public partial class
public class A
{
public string Str;
}
以上就不能在另一个地方定义相同的类了。
partial是部分类的意思
public partial class A
{
public string Str;
}
在另一个.cs文件里可以再定义这个类
public partial class A
{
public string Str1;
}
get和set方法
属性中用,get是返回某个字段的值,set是设置某个字段的值:
int var;
public int Var
{
get{return var;}
set{var=vaule;}
}
this关键字
最外面肯定是个类
class SB
{
public Student(string name, int age)
{
this.name = name;
this.age = age;
}
}
this就是指的的那个“SB”
count()
引入using System.Linq;
e.g flights.SingleWays.Count() == 0
表示用于检查项目的数量
tolower()和toupper()
如果 string s = "AbCdEf";
那么 s.ToLower() = "abcdef"; // 转换为小写
相对的 s.ToUpper() = "ABCDEF"; // 转换为大写
c#中怎么定义字符串数组?
方法一:
string[] abc = new string[3];
abc[1] ="1";
abc[2] ="1";
abc[3] ="1";
方法二:
string[] abc = new string[]{"1","1","1"}
ArrayList定义
System.Collections.ArrayList类是一个特殊的数组(即动态数组)。
通过添加和删除元素,就可以动态改变数组的长度。
如ArrayList tmp3 = new ArrayList();
动态数组缩减容量
首先声明一个动态数组:ArrayList AL = new ArrayList();
缩减容量--AL.TrimToSize():将集合的容量减少到实际元素个数的大小
ArrayList转换为string[]
ArrayList list = new ArrayList();
list.Add("aaa");
list.Add("bbb");
//转换成数组
string[] arrString = (string[])list.ToArray(typeof( string)) ;
字符数组转化成string类型
char
[] charBuf =
new
char
[100];
string s =
new
string(charBuf);
string类型转化成字符数组
string strinput;
char[] s = striput.toCharArray();
数组,ArrayList和List三者的区别
数组
数组在c#中最早出现的。在内存中是连续存储的,如:
但是数组存在一些不足的地方。在数组的两个数据间插入数据是很麻烦的,而且在声明数组的时候必须指定数组的长度,数组的长度过长,会造成内存浪费,过段会造成数据溢出的错误。如果在声明数组时我们不清楚数组的长度,就会变得很麻烦。
针对数组的这些缺点,C#中最先提供了ArrayList对象来克服这些缺点.
ArrayList
ArrayList是命令空间System.Collections下的一部分,在使用该类时必须进行引用,同时继承了IList接口,提供了数据存储和检索。ArrayList对象的大小是按照其中存储的数据来动态扩充与收缩的。所以,在声明ArrayList对象时并不需要指定它的长度。
从上面例子看,ArrayList好像是解决了数组中所有的缺点,为什么又会有List?
我们从上面的例子看,在List中,我们不仅插入了字符串cde,而且插入了数字5678。这样在ArrayList中插入不同类型的数据是允许的。因为ArrayList会把所有插入其中的数据当作为object类型来处理,在我们使用ArrayList处理数据时,很可能会报类型不匹配的错误,也就是ArrayList不是类型安全的。在存储或检索值类型时通常发生装箱和取消装箱操作,带来很大的性能耗损。
装箱与拆箱的概念:
装箱:就是将值类型的数据打包到引用类型的实例中
比如将string类型的值abc赋给object对象obj
拆箱:就是从引用数据中提取值类型
比如将object对象obj的值赋给string类型的变量i
泛型List
因为ArrayList存在不安全类型与装箱拆箱的缺点,所以出现了泛型的概念。List类是ArrayList类的泛型等效类,它的大部分用法都与ArrayList相似,因为List类也继承了IList接口。最关键的区别在于,在声明List集合时,我们同时需要为其声明List集合内数据的对象类型。
上例中,如果我们往List集合中插入int数组123,IDE就会报错,且不能通过编译。这样就避免了前面讲的类型安全问题与装箱拆箱的性能问题了。
总结:
数组的容量是固定的,您只能一次获取或设置一个元素的值,而ArrayList或List<T>的容量可根据需要自动扩充、修改、删除或插入数据。
数组可以具有多个维度,而 ArrayList或 List< T> 始终只具有一个维度。但是,您可以轻松创建数组列表或列表的列表。特定类型(Object 除外)的数组的性能优于ArrayList的性能。 这是因为 ArrayList的元素属于 Object 类型;所以在存储或检索值类型时通常发生装箱和取消装箱操作。不过,在不需要重新分配时(即最初的容量十分接近列表的最大容量),List< T>的性能与同类型的数组十分相近。
在决定使用 List<T> 还是使用ArrayList 类(两者具有类似的功能)时,记住List<T> 类在大多数情况下执行得更好并且是类型安全的。如果对List< T> 类的类型T使用引用类型,则两个类的行为是完全相同的。但是,如果对类型T使用值类型,则需要考虑实现和装箱问题。
c#中的static
提起static,一般理解为静态、全局。
何为static?我理解的static属于程序的直属单位,而非static就是非直属单位。
举一个非常常见的例子,中国有4个直辖市,北京、上海、天津、重庆,这些相当于static,而广州、南京、杭州等就是非static,中央可以直接管理北京、上海、天津、重庆,而广州、南京、杭州应由各省政府管理,Main方法可以直接调用static,而调用非static需要实例化。
class City()
{
//4个直辖市static 静态全局类型
public static void Beijing(){}
public static void ShangHai(){}
public static void Tianjin(){}
public static void Chongqing(){}
//其他城市 非静态
public void Guangzhou(){}
public void Nanjing(){}
}
void Main()
{
//调用static类型的方法
City.Beijing();//调用北京
City.Shanghai();//调用上海
//调用非static类型的方法
//没有直接调用权利,必须先实例化
City chengShi=new City();
chengShi.Guangzhou();//调用广州
}
c#中String类的几个方法(IndexOf,Substring)
String.IndexOf 方法(Char,Int32,Int32)
String.IndexOf(value,startIndex,count)
参数
value:要查找的unicode字符,startIndex:搜索起始位置,count:要检查的字符位置数
IndexOf 方法是返回一个位置,是整数值,找不到的情况下返回-1,索引序列是从左到右(起始值是0)
Substring是字符串截取,返回值是一个截取后的字符串
收藏
举报
TAG: