引用地址:http://www.jb51.net/article/54185.htm

本文实例汇总了C#中@的用法,对C#程序设计来说有不错的借鉴价值。具体如下:

一 字符串中的用法

1.学过C#的人都知道C# 中字符串常量可以以@ 开头声名,这样的优点是转义序列“不”被处理,按“原样”输出,即我们不需要对转义字符加上 \ (反斜扛),就可以轻松coding。如,

1
string filePath = @"c:\Docs\Source\a.txt" // rather than "c:\\Docs\\Source\\a.txt"

2.如要在一个用 @ 引起来的字符串中包括一个双引号,就需要使用两对双引号了。这时候你不能使用 \ 来转义爽引号了,因为在这里 \ 的转义用途已经被 @  “屏蔽”掉了。如,

1
@"""Ahoy!"" cried the captain."  // 输出为: "Ahoy!" cried the captain.

这有点像SQL中的单引号常量处理方式:

1
2
DECLARE @msg varchar(100)
SET @msg = ''Ahoy!'' cried the captain.' -- 输出为: 'Ahoy!' cried the captain.

3.@会识别换行符

其实这个特性,我不知道怎么描述,只是偶然发现的,先来看看下面的代码:

1
2
3
4
5
6
string script = @"
<script type=""type/javascript"">
function doSomething()
{
}
</script>";

这段代码在cs文件中写js,结构就很清晰了,正常情况我们是这样coding的:

?
1
string script2 = "<script type=\"type/javascript\">function doSomething(){}</script>";

或者:

1
2
3
4
string script3 =
"<script type=\"type/javascript\">" +
"function doSomething(){ " +
"}</script>";

通常我们会选择后者,因为js代码一般比较长,或者方法体很大,或者需要连接其他变量,这样结构比较清晰。

注意:如果“拼接”的次数很多,应该考虑使用StringBuilder了,有助于提高性能。

还有一种场景,也很常见,在程序中拼接 SQL 语句,如

1
2
3
private const string SQL_INS_USER = @"
INSERT INTO t_User([UserName], [Password], Email) 
 VALUES(@UserName, @Password, @Email)";

这样就像写存储过程一般,保持相当高的代码清晰度。然而,我们需要关注一个问题:字符串长度看下面的测试代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private const string SQL_INS_USER1 = @"
  INSERT INTO t_User([UserName], [Password], Email) 
 VALUES(@UserName, @Password, @Email)";
private const string SQL_INS_USER2 = @"INSERT INTO t_User([UserName], [Password], Email) 
 VALUES(@UserName, @Password, @Email)";
private const string SQL_INS_USER3 = @"INSERT INTO t_User([UserName], [Password], Email) VALUES(@UserName, @Password, @Email)"
static void Main(string[] args)
{
  Console.WriteLine(SQL_INS_USER1.Length);  // 126 
  Console.WriteLine(SQL_INS_USER2.Length);  // 112
  Console.WriteLine(SQL_INS_USER3.Length);  // 86
}

这里可以看到三个字符串长度分别相差了,14=126-112和26=112-86,注意观察了,在代码编辑器中,SQL_INS_USER1 中第一个换行符号之后,我缩进13个空格(INSERT之前),而
SQL_INS_USER2 中第一个换行符号之后,我缩进25个空格(VALUES之前),
那么,加上一个换行符,刚刚好 14和26

如此编写代码,虽然提高了代码的清晰度和简便性,却无行中带来了另一个问题:字符长度!
很多场景下我们希望字符串越短越好,如,通过ADO.NET 发送 SQL 语句给数据库执行。
所以还是慎用之!

二 标识符中的用法

在 C#  规范中, @  可以作为标识符(类名、变量名、方法名等)的第一个字符,以允许C# 中保留关键字作为自己定义的标识符。

如下代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
class @class
{
  public static void @static(bool @bool) {
   if (@bool)
     System.Console.WriteLine("true");
   else
     System.Console.WriteLine("false");
  }  
}
class Class1
{
  static void M() {
   cl\u0061ss.st\u0061tic(true);
  }
}

注意,@虽然出现在标识符中,但不作为标识符本身的一部分。
因此,以上示例,定义了一个名为 class 的类,并包含一个名为 static 的方法,以及一个参数名为了 bool 的形参。

这样,对于跨语言的移植带来了便利。因为,某个单词在 C#  中作为保留关键字,但是在其他语言中也许不是。

转载于:https://www.cnblogs.com/live-and-learn077/p/5543582.html

C#中@的用法总结(转)相关推荐

  1. c++中static_cast用法与uchar/char的区别

    1.c++中static_cast用法 static_cast是指显性类型强制转换,如: int a = static_cast<int>(120.34); 结果为a= 120. 和C语言 ...

  2. 简单介绍Python中异常处理用法

    这篇文章主要给大家分享的是 Python中异常处理用法,为了保证程序的健壮性与容错性,即在遇到错误时候程序不会崩溃,我们需要对异常进行处理,下面来看看文章对此的用法,需要的朋友可以参考一下 为了保证程 ...

  3. 关于OpenCV中常见函数用法总结

    关于OpenCV中常见函数用法总结 一 一般Mat的赋值操作 二 求Mat中的最大值以及最小值 三 randn()函数给图像添加高斯噪声 四 mean()函数的用法 五 系统计时器 六 矩阵之间的四则 ...

  4. java中import用法

    java中import用法 单类型导入(single-type-import),例如import java.io.File; 按需类型导入(type-import-on-demand),例如 impo ...

  5. 一个线程中lock用法的经典实例

    1 /* 2 该实例是一个线程中lock用法的经典实例,使得到的balance不会为负数 3 同时初始化十个线程,启动十个,但由于加锁,能够启动调用WithDraw方法的可能只能是其中几个 4 作者: ...

  6. 几个比较好用的Windows API在C#中的用法。

    几个比较好用的Windows API在C#中的用法. #region Windows Api 定义 ///   /// 模拟鼠标事件   ///   /// 鼠标事件的Enum   /// X座标   ...

  7. python管道界面_python中管道用法入门实例

    本文实例讲述了python中管道用法.分享给大家供大家参考.具体如下: #!coding=utf-8 import multiprocessing def consumer(pipe): output ...

  8. MVC中HtmlHelper用法大全

    MVC中HtmlHelper用法大全参考 解析MVC中HtmlHelper控件7个大类中各个控件的主要使用方法(1) 2012-02-27 16:25 HtmlHelper类在命令System.Web ...

  9. mysql raiserror_RAISERROR在SQL Server数据库中的用法

    raiserror  是由单词 raise error 组成 raise  增加; 提高; 提升 raiserror 的作用: raiserror 是用于抛出一个错误.[ 以下资料来源于sql ser ...

  10. 查询前几条记录SQL在不同数据库中的用法

    13,(1)查询前几条记录SQL在不同数据库中的用法; 1. ORACLE SELECT * FROM TABLE1 WHERE ROWNUM<=N 2. INFORMIX SELECT FIR ...

最新文章

  1. OpenCV2学习笔记(一)
  2. linux命令date
  3. mysql Integer Types (Exact Value) - INTEGER, INT, SMALLINT, TINYINT, MEDIUMINT, BIGINT
  4. 鸟哥的Linux私房菜(基础篇)- 一个简单的 SPFdisk 分割实例
  5. OKR和KPI的区别是啥?
  6. 果粉期待已久,iPhone 6s 或年底发布
  7. Android mock for循环,Android单元测试(五):依赖注入,将mock方便的用起来
  8. (转)替换回车符为换行符
  9. deebot地面清洁机器人怎么关_买扫地机器人还是吸尘器?看完你就明白了
  10. sublime配置python开发环境_【教程】把Sublime Text 2用作Python的IDE去实现Python的开发...
  11. 给小朋友讲故事——食盐的重要性实验
  12. 市场分析-全球与中国木槿果实提取物市场现状及未来发展趋势
  13. 腾讯云产品文档----负载均衡
  14. CVE-2021-1647:Microsoft Defender远程代码执行漏洞通告
  15. Google的垂直搜索
  16. Open3d Point cloud outlier removal 点云异常值移除
  17. 美通企业周刊 | 中国平安将深度参与深圳公共住房建设;北京环球度假区将引入IMAX影院...
  18. 普通中继模型-吞吐量
  19. Android 各 API Level 权限变更和功能限制汇总
  20. NEERC 2014, Eastern subregional contest(汇总)

热门文章

  1. 定义接口.定义接口成员
  2. Quartz学习(一)
  3. 如果抛开 Spring,如何自己实现 AOP?面试必问!
  4. 这些年我用过的6个API接口在线管理平台
  5. 分表分页/跨库分页为什么这么难?
  6. 百度开源超级链技术方案!
  7. 运维半夜给我打电话,弹幕服务产生大量异常日志,没办法起床排bug...
  8. CTO发飙:不要在Java代码中写set/get方法了,逮一次罚款***
  9. 中国 X86 服务器市场 10 年来首次负增长
  10. 5G 时代,一加的机会在哪里?