首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么我不能在C#中使用While(1)?

在C#中,不能使用while (1)的原因是这种写法不符合C#语言的语法规则。C#中的while循环需要一个布尔表达式作为条件,这个表达式的值将在每次循环开始时进行评估。当条件为true时,循环体内的代码将被执行。当条件为false时,循环将终止。

在C#中,while (1)的写法是不正确的,因为1不是一个布尔值。C#中的整数值1对应的布尔值是true,但是这种写法仍然不符合语法规则。为了使循环一直执行,可以使用以下写法:

代码语言:csharp
复制
while (true) {
    // 循环体内的代码
}

这样,循环将一直执行,直到遇到break语句或程序被强制终止。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MyBatis 为什么建议使用 where 1=1

1 错误的改造方式 既然是去掉 where 1=1,那最简单的方式就是将它直接从代码删除了,如下代码所示: <!...1,并且把第一个 name 查询的 and 去掉了,以防 SQL 查询报错。...传任何参数的请求 此时我们可以传递任何参数(查询所有数据),如下图所示: 生成的 SQL 语句如下: 传递 1 个参数的请求 也可以传递 1 个参数,根据 name 进行查询,如下图所示: 生成的...,无论是任何查询场景,传一个或者传多个参数,或者直接传递任何参数,都可以轻松搞定。...and 关键字删除掉,从而不会导致 SQL 语法错误,这一点官方文档也有说明,如下图所示: 3 总结 在 MyBatis ,建议尽量避免使用无意义的 SQL 拼接  where 1=1,我们可以使用标签来替代

58310

MyBatis 为什么建议使用 where 1=1

错误的改造方式 既然是去掉 where 1=1,那最简单的方式就是将它直接从代码删除了,如下代码所示: <!...1,并且把第一个 name 查询的 and 去掉了,以防 SQL 查询报错。 ​...传任何参数的请求 此时我们可以传递任何参数(查询所有数据),如下图所示: 生成的 SQL 语句如下: 传递 1 个参数的请求 也可以传递 1 个参数,根据 name 进行查询,如下图所示...标签之后,无论是任何查询场景,传一个或者传多个参数,或者直接传递任何参数,都可以轻松搞定。 ​...and 关键字删除掉,从而不会导致 SQL 语法错误,这一点官方文档也有说明,如下图所示: 总结总结 在 MyBatis ,建议尽量避免使用无意义的 SQL 拼接 where 1=1,我们可以使用

76810
  • Java 为什么推荐在 while 循环中使用 sleep()

    前言最近逛 CSDN 看到一篇文章,文章大意是说为什么在循环中推荐使用 sleep 操作,原因在于线程挂起和唤醒会有很大的性能消耗,并推荐使用 Timer 及 ScheduledExecutorService...= true; public static void main(String[] args) { while (FLAG) { try {...可能会导致忙等待 // 如 FLAG 变量状态未改变 那么线程可能一直循环,并不断进行线程挂起和唤醒原因是否正确主要原因和原文博主所说有很大的关系但不完全正确:我们都知道 Java 线程实际对应着操作系统的一个线程...比如微服务体系,客户端上报实例状态,或者服务端检测客户端状态都会使用定时轮询的机制。...在 Java AQS 等待获取锁和线程池任务为空等待新任务时,会使用等待和唤醒操作轮询机制 和 等待和唤醒 一般会结合使用,避免线程频繁的挂起和唤醒。

    1K30

    为什么建议你使用Python3.7.3?

    这个问题在Python中比较常见,说明是本地的SSL验证出现了问题,一般在Requests的使用我们一般会这么进行处理: >>> import requests >>> session = requests.Session...https的去验证SSL证书,不过这里的问题是使用的是Aiohttp库,并没有Verify这个参数,所以我们并不能使用这个去忽略这个问题。...解决一下 Goole了一下,发现其实不止一个人出现了这个问题,已经有老哥在Aiohttp的Issue里面提了相关的问题了,可以参考https://github.com/aio-libs/aiohttp...可惜的环境之前是3.7.3 我们知道了问题的解决办法,我们再去看看为什么会有这个问题?...最后的小建议 最后建议大家能够使用3.7.4的时候尽量不使用3.7.3版本,虽然3.8也可以避免这个问题,但是3.8还是刚推出,BUG问题还是很多的,所以目前这个阶段大家还是尽量使用3.7.4。

    2.1K30

    为什么建议你使用Java序列化

    作为一名Java开发,为什么建议你在开发避免使用Java序列化?...Java提供了一种序列化机制,这种机制能将一个对象序列化成二进制形式,用于写入磁盘或输出到网络,同时将从网络或者磁盘读取的字节数组,反序列化成对象,在程序中使用。 ?...Java序列化缺陷 我们在用过的RPC通信框架,很少会发现使用JDK提供的序列化,主要是因为JDK默认的序列化存在着如下一些缺陷:无法跨语言、易被攻击、序列化后的流太大、序列化性能太差等。 1....它使用 T-L-V(标识 - 长度 - 字段值)的数据格式来存储数据,T 代表字段的正数序列 (tag),Protocol Buffers 将对象的每个字段和正数序列对应起来,对应关系的信息是由生成的代码来保证的...Java 默认的序列化虽然实现方便,但却存在安全漏洞、跨语言以及性能差等缺陷,所以我强烈建议你避免使用 Java 序列化。

    1.9K20

    SQL为什么不要使用1=1

    编写SQL语句就像炒菜,每一种调料的使用都可能会影响菜品的最终味道,每一个SQL条件的加入也可能会影响查询的执行效率。那么 1=1 存在什么样的问题呢?为什么又会使用呢?为什么使用 1=1?...但是,如果我们告诉它一些无关紧要的信息,比如“要一本书,它是一本书”,这并不会帮助管理员更快地找到书,反而可能会让他觉得困惑。...在某些复杂的查询场景,即使是简单的 1=1 也可能对优化器的决策造成不必要的影响,比如导致全表扫描。...代码的可读性和清晰性非常重要,特别是在团队协作的环境。习惯养成:即使在当前的数据库系统1=1不会带来性能问题,习惯了写不必要的代码可能会在其他情况下引入实际的性能问题。...-- 更多条件... --> 在 MyBatis ,避免使用 1=1 的典型方法是利用动态SQL标签(如 )来构建条件查询。

    11710

    为什么在容器不能 kill 1 号进程?

    使用容器的理想境界是一个容器只启动一个进程,现实中有时是做不到的。比如容器除了主进程外还启动辅助进程,做监控或者logs;再比如程序本身就是多进程的。...而容器也是由init进程直接或间接创建了Namespace的其他进程。 linux信号 而为什么能在容器kill 1号进程呢?进程在收到信号后,就会去做相应的处理。...运行命令 kill -9 1 里的参数“-9”,就是指发送编号为 9 的这个 SIGKILL 信号给 1 号进程。 为什么在容器不能kill 1号进程? 对于不同的程序,结果是不同的。...把c程序作为1号进程就无法在容器杀死,而go程序作为1号进程却可以。 运行 kill 1 时,希望把 SIGTERM 发送给 1 号进程,就像下图中带箭头虚线。...IMAGE COMMAND CREATED 重点总结 “为什么在容器不能 kill 1 号进程?”。

    19810

    为什么实际业务建议直接使用POI操作Excel?

    一: 使用场景 在日常的系统开发,系统支持批量数据的操作是一个很常见的功能,其中,最常用的方式是使用excel表格对数据进行批量添加、删除,如:批量新建订单、批量添加商品等。...() --》 执行读取Excel文件的所有sheet   4、ExcelReader实例.finish() --》完成读取操作,并关闭流(一定要注意关闭流,因为easyExcel是使用磁盘的方式进行数据解析...sheet,再将 sheet插入到excel   4、ExcelWriter实例.finish() --》完成写入操作,并关闭流(一定要注意关闭流,因为easyExcel是使用磁盘的方式进行数据解析,...3、@ExcelIgnore: 被标注的属性参加Excel的读写,相当于直接省略。...如果这里抛出异常则 继续读取下一行。

    1.4K10

    什么是线程组,为什么在 Java 推荐使用

    在线程组,如果发生未捕获异常,可以通过 Thread.UncaughtExceptionHandler 进行处理。 在 Java ,虽然线程组是一种功能强大的机制,但实际上并不推荐使用。...下面主要从以下几个方面说明: 1、难以扩展 在平常的开发,当我们需要对线程进行动态调度时,线程组往往过于笨重,这导致了代码难以扩展。...在实践,像 Executor 这样的 API 已经为线程管理提供了更加强大、可控的解决方案,相比之下,线程组已经逐渐退出 Java 中被广泛使用的范畴。...3、容易引起歧义 在 Java ,虽然 ThreadGroup 的设计旨在通过将一组线程分到同一个容器来轻松管理和控制它们,但如果使用错误,可能会导致线程状态。...因此,在 Java ,线程组已基本过时,推荐使用 Executor 框架等新的更实用的工具来进行线程管理。

    29020

    Python 为什么建议使用 time.sleep 实现定时功能?

    有时候,我们想实现一个非常简单的定时功能,例如:让一个程序每天早上 8 点调用某个函数 但我们又不想安装任何第三方库,也不会使用 crontab 或者任务计划功能,就想使用纯 Python 来实现 可能有同学会这样写代码...: import time import datetime def run(): print('是需要被每天调用的函数') def schedule(): target_time...datetime.datetime.now() delta = (target_datetime - now).total_seconds() time.sleep(delta) run() while...') def schedule(): last_run = None while True: now = datetime.datetime.now()...总结 如果能用 crontab 或者任务计划,那么这是最优选择;其次,使用 Python 专用的定时模块;最次,才是使用 time.sleep 来实现 如果不得不用 time.sleep,那么应该尽量缩短检查的间隔

    4.3K10

    52-R茶话会-十二:为什么建议你使用 rm(list=ls())

    Ref Links : Chapter 1 Saving source and blank slates | What They Forgot to Teach You About R (rstats.wtf...为什么建议你使用 rm(list=ls()) 你可能会经常在脚本遇到rm(list=ls()),尤其是某些workflow 的内容。 它们的本意确实是好的:希望开启一个新的R。...这也是建议如此操作的原因。...,如stringsAsFactors = FALSE,而未在脚本声明,则其他使用者也会报错; 可能外部读取使用了相对路径,而在命令行中直接修改了路径setwd(),而此时又未在脚本声明新的路径,导致重启...; 避免在脚本中使用rm(list=ls())、setwd(),可以使用rs.restartR() 替代rm(list=ls()); 将重要的对象导出到output 文件夹内,保存为.Rdata,其他脚本如果需要使用可以直接读取

    1.7K20

    关于Spring的@Async注解以及为什么建议使用 - Java技术债务

    指定线程池的名称,@Async默认异步配置使用的是SimpleAsyncTaskExecutor,该线程池默认来一个任务创建一个线程,若系统不断的创建线程,最终会导致系统占用内存过高,引发OutOfMemoryError...defaultExecutor : new SimpleAsyncTaskExecutor()); } 为什么建议直接使用 @Async 注解?...在泰山版《阿里巴巴开发手册》规定开发建议使用 Async 注解,这是为什么?在实际开发,异步编程已经成为了一个必备的技能。...可能会导致死锁问题:如果异步操作包含了阻塞操作,可能会导致线程池中的线程被阻塞,从而导致死锁问题。 综上所述,直接使用 Async 注解可能会导致各种问题,因此建议直接使用 Async 注解。...如何更好地使用 Async 注解 虽然建议直接使用 Async 注解,但是在某些情况下,使用 Async 注解仍然是一个不错的选择。

    7710

    关于 java 的 set,get方法,而为什么推荐直接使用public

    不知道有没有人遇到过,有一段时间,都觉得那些 set,get的用处何在,直接写一个public直接拿不就行了,多爽,但是随着使用的频繁,越来越想去搜索一下这个问题,而不是按照官方的推荐,前辈们的使用都是建议...这里引入其中的一句话: 在任何相互关系,具有关系所涉及的各方都遵守的边界是十分重要的事情,当创建一个类库时,就建立了与客户端程序员之间的关系,他们同样也是程序员,但是他们是使用你的类库来构建应用...即使你希望客户端程序员不要直接操作你的类的某些成员,但是如果没有任何访问控制,将无法阻止此事发生。所有的东西都将赤裸裸的暴露在世人面前。...举一个简单的例子,这边有处理苹果的逻辑,即get,set,但是至于怎么操作,这是这边的工作,不想让你知道,是怎么摘的,怎么吃得。所以只有自己本身才能调用,这也就是private修饰的作用。...综上所述,写到这里,诞生了一个想法,其实set ,get ,public,对于它们使用完全取决于我们程序员自己,为了让项目之间的逻辑更加清晰,有些标准自上而下,慢慢的传了下来,无论你使用那种,但是有一个东西是无法避免的

    1.5K20

    背锅运维:搭起来赔钱给你:分享Ubuntu20和Centos7使用kubeadm搭建k8s集群。

    安装的ubuntu20默认没有selinux这东西,因此涉及关闭 关闭swap sudo swapoff -a # 临时 sudo sed -ri 's/....刚才提到,在部署calico的过程3台节点都需要拉取相关镜像,可以到其中1台Node上查看有没有镜像了: tantianran@test-b-k8s-node02:~$ sudo docker images...--ignore-preflight-errors=all 忽略检查的错误。...配置kubectl使用的连接k8s认证文件 # 普通用户要开始使用集群,您需要以普通用户身份运行以下命令: mkdir -p $HOME/.kube sudo cp -i /etc/kubernetes...这时就需要重新创建token,可以直接使用命令快捷生成: kubeadm token create --print-join-command 8.

    84411

    (10)C#偷懒的开始永无止境的循环?

    太菜了吧》(6)多晦涩的专业术语原来都会那么简单—— 布尔逻辑 《看聊天记录都学不会C#?太菜了吧》(5)C# 可以用中文名变量?—— 输入、运算 《看聊天记录都学不会C#?...太菜了吧》(4)C# 的尚方宝剑 “先斩后奏”—— 变量运算 《看聊天记录都学不会C#?太菜了吧》(3)变量:大哥呢?$:小弟罩着你!—— 输出变量 《看聊天记录都学不会C#?...太菜了吧》(1)从今天开始是一个游戏开发者—— helloworld 的其它教程 教程点击进去将会有目录 《看聊天记录都学不会C语言?太菜了吧(1在大佬群里问基础问题没人理?...小媛:知识点的重复就让度日如年了。 小C:是嘛,那我们再渡过个几年? 小媛:,怕了怕了。 小C:哈哈哈,那我们就正式开始吧,这一节我们将循环。 小媛:就是一直重复吗? 小C:是这个意思。...小媛:原来如此,怪不得你 i 等于 10,等于 10 的话 i<10 这个条件肯定是判断不正确的,那么这个循环肯定是执行的,但是由于是 do while 所以肯定会有一次循环。

    33720

    番外特别篇之 为什么建议你直接使用UIImage传值?--从一个诡异的相册九图连读崩溃bug谈起

    关于"番外特别篇" 所谓"番外特别篇",就是系列文章更新期间内,随机插入的一篇文章.目前正在更新的系列文章是 实现iOS图片等资源文件的热更新化.但是,这两天,被一个自己App诡异的相册读取的Bug...1.排除通用逻辑问题 Coder有些许高傲,有时候是有利于自己更冷静地处理问题的.稍微不自信点的童鞋,可能就会怀疑:代码是不是有什么特殊的临界判断没有加?...,是单个N个断点,最终确认了Crash的代码的准确位置.一个for循环,每次step 1,这下很明显地看到内存,几乎是 100M/张的速度在飙升,而图片本身的大小只有 1.5M/张.此处想说的是,打断点也是有技巧的...回到问题本身,用一句概括就是:永远不要直接传递UIImage对象.在需要传递UIImage的场景,请使用图片名或者NSData二进制对代替....真没想到,一个UIImage对象,竟然会二次引起高内存占用.最终的解决方法,就是在前一个页面传递 NSData数组,在赋值处,再使用imageWithData:转换为 UIImage.这样,内存使用基本没什么起伏

    1.6K70
    领券