目录
问题内容
解决方法
首页 后端开发 Golang 输出时如何获取输入?

输出时如何获取输入?

Feb 09, 2024 pm 12:30 PM
表单提交

输出时如何获取输入?

php小编苹果今天来给大家介绍一个常见的问题:在PHP中,当我们需要获取用户的输入时,应该如何进行输出呢?获取用户的输入是编写交互式程序的重要环节,因此掌握正确的方法十分重要。在PHP中,我们可以使用一些内置的函数来获取用户的输入,例如使用`fgets()`函数从标准输入中读取用户输入的一行内容,或者使用`fgetc()`函数从标准输入中读取一个字符。当然,我们也可以使用`$_GET`或`$_POST`超全局变量来获取用户通过表单提交的数据。无论是使用哪种方法,都需要注意对用户输入进行必要的验证和过滤,以确保程序的安全性和稳定性。希望以上介绍能够帮助到大家!

问题内容

我想要实现的是某种应用程序,它将大量信息记录到控制台(例如,从 0 到 1000000000000 的数字),并且能够通过在控制台中键入命令来停止执行(例如“停止”)。

我想到了使用 goroutine 的想法,但是,我无法输入命令,因为输入字段正在更改为输出。

这是我的代码:

package main

import (
    "bufio"
    "os"
)

var process bool = true

func commandHandler() {
    reader := bufio.NewReader(os.Stdin)
    for process {
        text, _ := reader.ReadString('\n')
        if text == "stop\r\n" {
            process = false
        }
    }
}

func task() {
    var i int64 = 0
    for ; i < 10000000000 || process; i++ {
        if i%30000000 == 0 { // Just to slow down an output for a while
            println(i)
        }
    }
}

func main() {
    go task()
    commandHandler()
}
登录后复制

以及我得到的结果。字母是我尝试输入的输入,数字是应用程序的输出

关于如何在我的 go 应用程序中进行正确的输入/输出有什么建议吗?

解决方法

我无法输入命令,因为输入字段正在更改为输出

您可以正常输入命令。当您键入它们时,它们会回显到您的控制台。这将与输出到控制台的其他所有内容结合在一起,这可能会让用户感到困惑 - 但不会让计算机感到困惑。

假设这实际上与您的操作系统匹配,您的程序运行得很好:

if text == "stop\r\n" {
登录后复制

在我的操作系统上没有 r。更便携的方法是使用 strings.trimspace 删除所有空格。

import (
  ...
  "strings"
) 
... 
...
        if strings.TrimSpace(text) == "stop" {
登录后复制

通过此更改,代码对我有用。正如您所说,输出和输入被插入到屏幕上,但您仍然可以输入 stop 并结束程序。

关于如何在我的 go 应用程序中进行正确的输入/输出有什么建议吗?

现实世界中几乎没有终端程序是交互式的。相反,命令行参数和环境变量在调用时提供其配置。 shell 重定向通常用于保留(在文件中)或分页(例如 |less)程序的任何长输出。

您会看到很多使用交互式终端模型的学术编程,其中程序提示用户并收集数据,但在现实世界中这种情况非常罕见,并且通常是一种不明智的复杂化。标准输入通常用于提供计算所需的数据输入,而不是用户命令(例如要操作或过滤的数据)。

正如 @tinkerer 所建议的,信号已经可以用来终止你的程序(详细信息是特定于操作系统的)。因此,实际上无需担心终端应用程序如何处理标准输入和输出的可视化表示,而这些标准输入和输出的插值只是为了终止程序。在 posix 环境中还有许多其他信号,其中一些信号完全面向用户并且可以用于任意目的。

一旦运行时需要更复杂的用户输入,程序通常会在套接字上侦听命令。对于此类程序,由于简单性和可访问性,提供 http 服务的 web 界面变得越来越普遍。

以上是输出时如何获取输入?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

layui登陆页面怎么设置跳转 layui登陆页面怎么设置跳转 Apr 04, 2024 am 03:12 AM

layui 登录页面跳转设置步骤:添加跳转代码:在登录表单提交按钮点击事件中添加判断,成功登录后通过 window.location.href 跳转到指定页面。修改 form 配置:在 lay-filter="login" 的 form 元素中添加 hidden 输入字段,name 为 "redirect",value 为目标页面地址。

layui怎么获取表单数据 layui怎么获取表单数据 Apr 04, 2024 am 03:39 AM

layui 提供了多种获取表单数据的方法,包括直接获取表单所有字段数据、获取单个表单元素值、使用 formAPI.getVal() 方法获取指定字段值、将表单数据序列化并作为 AJAX 请求参数,以及监听表单提交事件获取数据。

layui怎么实现前后端交互 layui怎么实现前后端交互 Apr 01, 2024 pm 11:33 PM

使用 layui 进行前后端交互有以下方法:$.ajax 方法:简化异步 HTTP 请求。自定义请求对象:允许发送自定义请求。Form 控件:处理表单提交和数据验证。Upload 控件:轻松实现文件上传。

Java中Serverlet的作用是什么 Java中Serverlet的作用是什么 Apr 12, 2024 pm 02:39 PM

Servlet 在 Java Web 应用程序中作为客户端-服务器通信的桥梁,负责:处理客户端请求;生成 HTTP 响应;动态生成 Web 内容;响应客户交互;管理 HTTP 会话状态;提供安全保护。

vue中event和$event区别 vue中event和$event区别 May 08, 2024 pm 04:42 PM

Vue.js 中,event 为原生 JavaScript 事件,由浏览器触发,而 $event 是 Vue 特定抽象事件对象,在 Vue 组件中使用。一般使用 $event 更方便,因为它经过格式化和增强,支持数据绑定。当需要访问原生事件对象特定功能时,使用 event。

如何使用 PHP 构建单页应用程序 如何使用 PHP 构建单页应用程序 May 04, 2024 pm 06:21 PM

使用PHP构建单页应用程序(SPA)的步骤:创建PHP文件,并加载Vue.js。定义Vue实例,并创建包含文本输入和输出文本的HTML界面。创建包含Vue组件的JavaScript框架文件。将JavaScript框架文件包含到PHP文件中。

Java Servlet的应用场景有哪些? Java Servlet的应用场景有哪些? Apr 17, 2024 am 08:21 AM

JavaServlet可用于:1.动态内容生成;2.数据访问与处理;3.表单处理;4.文件上传;5.会话管理;6.过滤器。示例:创建一个FormSubmitServlet来处理表单提交,将name和email作为参数,并重定向到success.jsp。

vue中的事件修饰符可以用于哪些场景 vue中的事件修饰符可以用于哪些场景 May 09, 2024 pm 02:33 PM

Vue.js 事件修饰符用于添加特定行为,包括:阻止默认行为 (.prevent)停止事件冒泡 (.stop)一次性事件 (.once)捕获事件 (.capture)被动的事件监听 (.passive)自适应修饰符 (.self)关键修饰符 (.key)

See all articles