C++中cout输出中文信息乱码问题及解决

目录
  • cout输出中文信息乱码问题
    • 问题描述
    • 解决办法
  • C++ 输出cout
    • 输出
    • 输出
    • 附录

cout输出中文信息乱码问题

问题描述

在实例化学生类对象时,对学生的姓名采用了形如“张三”这样的汉字信息,在输出学生姓名时出现了乱码问题(如下图):

解决办法

采用<windows.h>头文件中的SetConsoleOutputCP(CP_UTF8)函数来设置在显示器打印时的编码格式就解决了乱码问题。

完整代码如下:

#include <iostream>
#include <windows.h>

using namespace std;

class Student {
public:
    string name;
    int num;

    Student(const string &name, int num) : name(name), num(num) {}

    friend ostream &operator<<(ostream &os, const Student &student) {
        os << "name: " << student.name << " num: " << student.num;
        return os;
    }
};

int main() {
    SetConsoleOutputCP(CP_UTF8);
    Student s("张三", 1001);
    cout << s << endl;
    return 0;
}

C++ 输出cout

#include <cstring>
#include <iostream>

using namespace std;

int main()
{
    /*
    <<运算符  (可以进行 混合 拼接输出)
    */
    const char *s = "hhhhh";                                //字符串是const char*类型的,所以将字符串赋值给 char* 类型要加const关键字
    cout << "the length of the s is " << strlen(s) << endl; // strlen()是cstring库中的函数
    char str[10] = "ddddd";
    cout << "hello" << endl;
    cout << s << str << endl; //可以进行拼接输出
    // 如何打印字符串地址的值?
    //对于其他类型的指针,c++将其对应于void*,并打印地址的数值表示。如果要获得字符串的地址,则必须将其强制类型转换成其他类型
    cout << &str[0] << endl;        //invalid
    cout << (float *)s << endl;     //valid
    cout << (void *)str << endl;    //valid
    cout << (int *)"hello" << endl; //valid
    cout << "-------------------------------------------\n";
    /*
    put()方法  (可以进行 混合 拼接输出)
    用于显示字符 (也可以将int型的赋给它,它会将int转换成char,从而显示与该ascll码相对应的字符)
    */
    cout.put('d');
    cout.put('\n');
    cout.put('d').put('b').put('\n'); //可以进行拼接输出
    cout.put(65);
    cout.put(65.9); //put 浮点数65.9强制类型转换成整型数65(向下取整)
    cout.put('\n');
    cout << "-------------------------------------------\n";

    /*
    write()方法  (可以进行 混合 拼接输出)
    第一个参数提供了要显示的字符串的地址,第二个参数指出要显示多少个字符
    */
    const char *state1 = "Florida";
    const char *state2 = "Kansas";
    //state1、state3用于提供state2前面和后面的数据,以便程序员知道程序错误存取state2时发生的情况
    const char *state3 = "Euphoria";

    int len = strlen(state2);
    cout << "Increasing loop index:\n";
    int i;
    for (i = 1; i <= len; i++)
    {
        cout.write(state2, i);
        cout << endl;
    }
    // concatenate output
    cout << "Decreasing loop index:\n";
    for (i = len; i > 0; i--)
        cout.write(state2, i) << endl;
    // exceed string length
    cout << "Exceeding string length:\n";
    //我们发现:连续定义的字符串时连续存储的,中间用一个空格隔开 !!这可能因为编译器之间的差别而有所不同
    cout.write(state2, len + 5).write("\n", 1).write(state2, len + 4) << endl;

    /*
    write()也可以用于数值数据,您可以将数字的地址强制转换成char*,然后传递给他
    但这不会将数字转换为相应的字符,而是传输内存中储存的位表示。例如4字节的long值将作为四个独立的字节被传输,
    输出设备将把每个字节作为ASCLL码进行解释,最终显示出来的是四个字符的组合(有可能是乱码)
    */
    long val = 1094795585; // 二进制数01000001010000010100000101000001所对应的十进制数(每个字节都是65)
    cout.write((char *)&val, sizeof(long)).write("\n", 1);
    cout << "-------------------------------------------\n";

    /*
    刷新输出缓存区
    */
    cout << "Hello, good-looking! " << flush;
    cout << "Wait just a moment, please." << endl; //endl 刷新缓冲区,并插入一个换行符
    flush(cout);
    cout << flush; //ostream类对<<插入运算符进行了重载,使得下述表达式将被替换位函数调用flush(cout);
    return 0;
}

输出

the length of the s is 5
hello
hhhhhddddd
ddddd
0x406045
0x61feee
0x406063
-------------------------------------------
d
db
AA
-------------------------------------------
Increasing loop index:
K
Ka
Kan
Kans
Kansa
Kansas
Decreasing loop index:
Kansas
Kansa
Kans
Kan
Ka
K
Exceeding string length:
Kansas Euph
Kansas Eup
AAAA
-------------------------------------------
Hello, good-looking! Wait just a moment, please.

#include <iostream>

using namespace std;

int main()
{

    int n = 10;
    cout << "n\n";
    cout << n << " (decimal)\n";
    cout << hex << n << " (hexadecimal)\n";
    cout << oct << n << " (octal)\n";
    dec(cout); // ostream类重载了<<运算符,这使得上述用法与函数调用dec(cout)等价
    cout << n << " (decimal)\n";
    cout << "-------------------------------------------\n";

    //width()  只影响接下来显示的一个项目,然后字段宽度将恢复为默认值 0
    int w = cout.width(2); //width(int i)返回的是修改前字段宽度的值,而不是刚设置的值
    //fill(char c) 它更改的填充字符将一直有效,直到再次更改它为止
    cout.fill('*');
    cout << "default field width = " << w << ":\n"; //C++的原则:显示所有的数据比保持列的整洁更重要。输入上面设置了字段宽度为2,但这里依旧能将字符串“default field width = ”显示全
    cout.width(5);
    cout << "N"
         << ":\n";

    for (long i = 1; i <= 100; i *= 10)
    {
        cout.width(5);
        cout << i << ":\n";
    }
    cout << "-------------------------------------------\n";

    //设置浮点数的精度
    float price1 = 20.40;
    float price2 = 1.9 + 8.0 / 9.0;

    cout << "\"Furry Friends\" is $" << price1 << "!\n";
    cout << "\"Fiery Fiends\" is $" << price2 << "!\n";

    cout.precision(2); //修改输出浮点数的精度为2,设置后一直有效,直到再次更改它为止
    cout << "\"Furry Friends\" is $" << price1 << "!\n";
    cout << "\"Fiery Fiends\" is $" << price2 << "!\n";

    cout.precision(6);
    cout.setf(ios_base::showpoint); //showpoint是ios_base类声明中定义的类级静态常量,在成员函数的定义外面使用要加上作用域运算符(::)
    cout << "\"Furry Friends\" is $" << price1 << "!\n";
    cout << "\"Fiery Fiends\" is $" << price2 << "!\n";

    cout.precision(2);
    cout << "\"Furry Friends\" is $" << price1 << "!\n";
    cout << "\"Fiery Fiends\" is $" << price2 << "!\n";

    cout << "-------------------------------------------\n";

    int temperature = 63;
    cout << "Today's water temperature: ";
    cout.setf(ios_base::showpos); // show plus sign
    cout << temperature << endl;

    cout << "For our programming friends, that's\n";
    cout << std::hex << temperature << endl; // use hex
    cout.setf(ios_base::uppercase);          // use uppercase in hex
    cout.setf(ios_base::showbase);           // use 0X prefix for hex
    cout << "or\n";
    cout << temperature << endl;
    cout << "How " << true << "! oops -- How ";
    cout.setf(ios_base::boolalpha);
    cout << true << "!\n";

    cin.get();
    return 0;
}

输出

n
10 (decimal)
a (hexadecimal)
12 (octal)
10 (decimal)
-------------------------------------------
default field width = 0:
****N:
****1:
***10:
**100:
-------------------------------------------
"Furry Friends" is $20.4!
"Fiery Fiends" is $2.78889!
"Furry Friends" is $20!
"Fiery Fiends" is $2.8!
"Furry Friends" is $20.4000!
"Fiery Fiends" is $2.78889!
"Furry Friends" is $20.!
"Fiery Fiends" is $2.8!
-------------------------------------------
Today's water temperature: +63
For our programming friends, that's        
3f
or
0X3F
How 0X1! oops -- How true!

附录

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 详解C++ cout格式化输出完全攻略

    写算法题的时候突然发现自己忘记基本的C++:cout格式化输出了,赶紧拉出以前的C++学习笔记重新看一看. 部分内容来自教程:C语言中文网(一个很棒的网站) 有时希望按照一定的格式进行输出,如按十六进制输出整数,输出浮点数时保留小数点后面两位,输出整数时按 6 个数字的宽度输出,宽度不足时左边补 0,等等.C语言中的 printf() 函数使用以%开头的格式控制符,例如 %X.%.2f.%6d 等:C++ 中的 cout 对象则使用流操作算子(你也可以叫做格式控制符)或者成员函数进行控制. 使用

  • C++中cout的格式使用详细介绍

    1.cout和i/i++/++i的组合使用 i++ 和 ++i 是有着不同的含义,和 cout 组合使用也会得到不同的结果,下面给出一段代码: #include <iostream> using namespace std; int main(){ int i = 1; cout << ++i << i++ << i << i++ << ++i << endl; return 0; } 这段代码的结果是多少呢? A.233

  • C++char类型和输入输出优化

    目录 1.char类型 2.getchar.putchar.cin.get.cout.put 3.输入输出中文 1.char类型 char的全称是character,也就是字符的意思.顾名思义,char类型是专门为了存储字符而设计的. 计算机存储数字非常方便,只需要将其转化成二进制即可.但存储字符就有点麻烦了,一般都是通过对字符进行数字化编码.这也就是为什么char类型本质上是另外一种整数,因为它存储的其实是字符的数字编码. char一共有8个二进制位,即一个字节,理论上能够存储256个字符.基

  • C++中cout输出中文信息乱码问题及解决

    目录 cout输出中文信息乱码问题 问题描述 解决办法 C++ 输出cout 输出 输出 附录 cout输出中文信息乱码问题 问题描述 在实例化学生类对象时,对学生的姓名采用了形如“张三”这样的汉字信息,在输出学生姓名时出现了乱码问题(如下图): 解决办法 采用<windows.h>头文件中的SetConsoleOutputCP(CP_UTF8)函数来设置在显示器打印时的编码格式就解决了乱码问题. 完整代码如下: #include <iostream> #include <w

  • 详解Intellij IDEA中.properties文件中文显示乱码问题的解决

    首先,你可能会见到如下提示: File encoding is disabled because .properties file (see Settings|Editor|File Encodings|Properties Files) 具体如下图.没截全图,太大了,只截取了提示部分. 在这之前,我一直以为,我已经设置了我这个编辑器下的所有文件的编码格式都是utf-8,直到我这次要读取properties文件的时候,才惊讶的发现,我的properties文件并不都是utf-8的文件编码格式.然

  • 解决asp.net core在输出中文时乱码的问题

    前言 作为一个.NET Web开发者,我最伤心的时候就是项目开发部署时面对Windows Server上贫瘠的解决方案,同样是神器Nginx,Win上的Nginx便始终不如Linux上的,你或许会说"干嘛不用windows自带的NLB呢",那这就是我这个小鸟的从众心理了,君不见Stack Overflow 2016最新架构中,用的负载和缓存技术也都是采用在Linux上已经成熟的解决方案吗.没办法的时候找个适合的解决办法是好事,有办法的时候当然要选择最好的解决办法. 所幸,.ASP.NE

  • Java中HttpServletResponse响应中文出现乱码问题

    以字符串的形式输出. 1.response.getWriter().write("您好中国hello"); 如果这样输出的话.则浏览器结果为: 2.加上代码 response.setCharacterEncoding("UTF-8"); response.getWriter().write("您好中国hello"); 则浏览器结果为: 这是因为浏览器解析问题. 加上代码: response.setHeader("Content-type

  • Java中URL传中文时乱码的解决方法

    前言 Java中URL传中文时乱码的问题相信不少朋友都遇到过,最近就遇到一个问题,就是在Action当中把一条中文信息绑定在URL的后面,ActionForward到别一个页面时,用reqeust.getParameter取出是出现乱码的问题. 解决办法 1.对要进行URL传递的中文字符进行编码: String message = java.net.URLEncoder.encode("中文字符","utf-8"); 2.在取URL传递中文的页面对字符进行解码: S

  • escape函数解决js中ajax传递中文出现乱码问题

    本文实例讲述了escape函数解决js中ajax传递中文出现乱码问题,分享给大家供大家参考.具体方法如下: 一.问题描述: 本来网页特效中的escape()是将中文按iso-8859-1字符集进行url编码的,那样通过 request.getparameter()是能直接获取到请求参数的,但后来的javascript将escape()换成了unicode字符集编 码,如此一来,在jsp教程和servlet中就没法直接拿到请求参数了,具体原因我也不知道. 二.解决办法: 1.首先对中文字符进行两次

  • SecureCRT中文显示乱码问题的解决方法

    环境:SecureCRT登陆REDHAT5.3 LINUX系统 问题:vi编辑器编辑文件时文件中的内容中文显示乱码,但是直接使用linux系统terminal打开此文件时中文显示正常,确诊问题出现在客户端即SecureCRT的显示问题 解决方法: 1.修改远程linux机器的配置 [root@rhel ~]#vi /etc/sysconfig/i18n 把LANG改成支持UTF-8的字符集 如: LANG="zh_CN.UTF-8″ 或者是 LANG="en_US.UTF-8″  本文

  • 读写json中文ASCII乱码问题的解决方法

    今天要帮前端写一个小后台,就是读取数据然后转成json送给他,让他去展示.数据很简单,但是处理的时候遇到了一个问题,文件中涉及到了中文的处理,每次处理完写的json格式就是ASCII码,完全没办法用.代码如下: # -*- coding: utf-8 -*- import json import codecs f = codecs.open('data.txt', 'r', 'utf-8') content = json.load(f) print content[0]['id'] jsdata

  • Linux下Oracle中SqlPlus时上下左右键乱码问题的解决办法

    window下的sqlplus可以通过箭头键,来回看历史命令,用起来非常的方便. 但是在Linux下,会出现各种乱码,非常不方便,如下图所示,每次打错一个字符就需要重新打一遍. 解决办法:rlwrap 可以用来支持Oracle下sqlplus历史命令的回调功能,提高效率. 解决过程: 1.首先下载rlwrap和readline: readline-6.3.tar.gz rlwrap-0.30.tar.gz 2.安装readline包 tar -zxvf readline-6.3.tar.gz c

  • php版微信公众平台回复中文出现乱码问题的解决方法

    本文实例分析了php版微信公众平台回复中文出现乱码问题的解决方法.分享给大家供大家参考,具体如下: 微信公众平开发时碰到回复中文乱码了,这个问题小编发现是编码问题,其实只要把编码转成utf8就可以解决了,具体来看看. 很多微信公众平台的自动回复程序都是 ThinkWechat.class.php 这个类开发的,今天碰到一个莫名其妙的乱码问题,查问题发现是GB2312编码导致,所以要修改源码. 先增加一个方法: /** * 检测是否UTF-8 * @param $str * @return boo

随机推荐