在 C# 中不使用临时变量交换变量值
因此,假设你现在正在编写代码并想要交换变量值。你可能会做这样的事情:
var val_one = 123;
var val_two = 234;
var val_swap = val_one;
val_one = val_two;
val_two = val_swap;
Console.WriteLine("The value after swapping is: " + val_one + " and -> " + val_two);
现在在这里,你首先创建一个名为 val_swap
的临时变量,然后将 val_one
值复制到其中,以便在修改 val_one
值后,你可以轻松地将原始 val_one
值复制回 val_two
通过将 val_swap
中的值分配给它。
今天,我们将着眼于消除这个临时变量的使用,并在没有任何其他分配的情况下执行这样的交换。
在 C#
中使用元组赋值
你现在可以使用的一个非常简单的方法是使用 TUPLE
赋值,如下所示。
(val_one, val_two) = (val_two, val_one);
Console.WriteLine("The value after swapping from the tuple method is: " + val_one + " and -> " +
val_two);
输出:
The value after swapping from the tuple method is: 234 and -> 123
这个方法在 Python 中也已经使用过;但是,不受元组的影响。
但是,有时你必须使用技巧来获得想要的东西。让我们看一个下面的例子。
使用 +
运算符绕过 C#
中使用的临时变量
假设我们有两个数字; 7
和 9
。第一个变量的值为 7
,第二个变量的值为 9
。
如果我们将 9
添加到 7
,我们将得到 16
。现在让我们将 16
分配给第一个变量。
要将 9
作为第一个变量的值,你必须从第二个变量中减去 9
的值,即为 15-9 = 7
;使用这个值并从第一个变量中的 15
中减去它,现在得到值 9
。
val_one += val_two;
val_two = val_one - val_two;
val_one = val_one - val_two;
Console.WriteLine("The value after swapping is: " + val_one + " and -> " + val_two);
输出:
The value after swapping is: 234 and -> 123
你可以注意到它如何使用简单的算术来在交换时停止使用临时变量。另一方面,如果有非常大的准确值,这可能会变得无效,并且使用这种算法可能会导致一些值的丢失。
如果你想隐藏实现而不只是删除临时变量的使用,你可以使用以下内容。
在 C#
中使用函数交换值而不是显式实现来隐藏临时变量的使用
你可以执行以下操作。
static void swap(ref int x, ref int y) {
var temp = x;
x = y;
y = temp;
}
然后在下面调用它:
swap(ref val_one, ref val_two);
Console.WriteLine("The value after swapping is: " + val_one + " and -> " + val_two);
输出:
The value after swapping is: 234 and -> 123
如何在 C#
中使用 XOR
操作符来交换
让我们看看下面的代码。
val_one ^= val_two ^= val_one ^= val_two;
及其输出:
The value after swapping is: 0 and -> 123
你会注意到第一个值是 0
,即使第二个变量现在具有第一个变量的值并且可以正常工作。
那么我们如何解决这个问题呢?我们先写一段代码如下。
val_one ^= val_two;
val_two ^= val_one;
val_one ^= val_two;
现在输出是:
The value after swapping is: 234 and -> 123
发生什么了?我们先来了解第一个语句中给出的代码。
这可以扩展如下。
val_one = val_one ^ val_two;
val_two = val_two ^ val_one;
val_one = val_one ^ val_two;
现在你可以说第一个代码和后面介绍的代码差不多,那它怎么不工作,但后者表现得很好呢?
改变这些算术运算的顺序会产生不同的结果。在前面的代码中,val_one
与自身有一个 XOR
,因此结果为 0。
但是,在后者中,顺序已经定义,并且值已完美计算,因此存在差异。
但是,请记住不要使用 XOR
交换更高的代码级别。它不安全,应作为替代品保存。
相关文章
C# 中的 LINQ 分组
发布时间:2024/01/20 浏览次数:51 分类:编程语言
-
LINQ 中的 group by 用于按 C# 中的某个公共值对对象序列进行分组 C# 中的 LINQ 分组 LINQ 将类似 SQL 的查询功能与 C# 中的数据结构集成在一起。
使用 C# 在 LINQ 查询中按多列分组
发布时间:2024/01/20 浏览次数:167 分类:编程语言
-
这是一篇关于 LINQ 查询的使用以及我们如何使用 LINQ 查询按列分组的文章。本文简要介绍了使用 C# 进行的 LINQ 查询。此外,它还讨论了如何使用 LINQ 查询按多列对结果进行分组。
在 C# 中捕获多个异常
发布时间:2024/01/20 浏览次数:135 分类:编程语言
-
有两种主要方法可用于捕获 C# 中的多个异常,即 Exception 类和 catch 子句中的 if 语句。使用 C# 中的 Exception 类捕获多个异常 Exception 类用于表示 C# 中的一般异常。
C# 中为无效参数或参数引发的异常类型
发布时间:2024/01/20 浏览次数:71 分类:编程语言
-
本教程将教你如何在 C# 中为无效参数或参数抛出不同类型的异常。异常提供有关 C# 程序中的运行时错误或预期不会发生或违反系统/应用程序约束的条件的信息。在本教程中,你将学习与无效参
C# 中的树形数据结构
发布时间:2024/01/20 浏览次数:73 分类:编程语言
-
C# 中的树是本文讨论的主题。一种以树的形式组织起来的层次数据称为树数据结构。C# 中的树将是本文讨论的主题。数据结构是我们需要知道的第一件事。
C# 中的 lock 语句
发布时间:2024/01/20 浏览次数:166 分类:编程语言
-
C# 中 lock 语句指定的代码部分不能被多个线程同时访问。C# 中的 lock 语句 lock(obj) 语句规定,在 C# 中,下面这段代码不能被多个线程同时访问。
等待线程在 C# 中完成
发布时间:2024/01/20 浏览次数:70 分类:编程语言
-
等待 C# 中的线程完成的主要方法有两种:Task.WaitAll()和 Thread.Join()函数。用 C# 中的 Task.WaitAll() 方法等待线程完成 C# 中的 [Task.WaitAll() 方法)用于等待 Task 类的所有对象的完成。
C# 中的线程与任务
发布时间:2024/01/20 浏览次数:127 分类:编程语言
-
Thread 类创建一个实际的 OS 线程,而 Task 类创建一个在线程池中异步执行的任务。Thread 类在 C# 中创建实际的操作系统级别的线程。用 Thread 类创建的线程会占用堆栈内存等资源,上下文的 CPU 开