C++:关系运算符: < 、 > 、 < = 和 >=

本文介绍了C++中的关系运算符,包括小于(<)、大于(>)、小于等于(<=)和大于等于(>=)。这些运算符具有从左到右的关联性,适用于算术或指针类型的操作数,返回bool值。当比较指针时,若指向同一类型的对象,结果取决于它们在内存中的相对位置。比较不同类型指针需满足特定条件,如派生关系或转换为void*。此外,文章还提到了比较类类型成员指针的规则。

C++:关系运算符: < 、 > 、 < = 和 >=

语法

expression < expression
expression > expression
expression <= expression
expression >= expression

备注

二进制关系运算符确定下列关系:

小于 (<)

大于 (>)

小于或等于 (<=)

大于或等于 (>=)

关系运算符具有从左到右的关联性。 关系运算符的两个操作数必须是算术或指针类型。 它们将生成类型的值 bool 。 false 如果表达式中的关系为 false,则返回的值为 (0) ; 否则返回的值为 true (1) 。

示例

// expre_Relational_Operators.cpp
// compile with: /EHsc
#include <iostream>

using namespace std;

int main() {
   cout  << "The true expression 3 > 2 yields: "
         << (3 > 2) << endl
         << "The false expression 20 < 10 yields: "
         << (20 < 10) << endl;
}

前面的示例中的表达式必须括在括号中,因为 () 的流插入运算符的 << 优先级高于关系运算符。 因此,未括在括号中的第一个表达式的计算结果将为:

(cout << "The true expression 3 > 2 yields: " << 3) < (2 << "\n");

标准转换中涵盖的常用算术转换将应用于算术类型的操作数。

比较指针

在比较两个指向同一类型的对象的指针时,结果由程序的地址空间中所指向的对象的位置决定。 也可以将指针与计算结果为0的常量表达式或类型为的指针进行比较 void * 。 如果对类型的指针进行了指针比较,则 void * 另一个指针将隐式转换为类型 void * 。 然后进行比较。

不能比较两个类型不同的指针,除非:

一个类型是派生自另一个类型的类类型。

至少一个指针会显式转换 (将) 转换为类型 void * 。 (其他指针将隐式转换为转换的类型 void * 。 )

两个指向同一对象的相同类型的指针一定是相等的。 如果比较两个指向对象的非静态成员的指针,则以下规则将适用:

如果类类型不为 union ,并且两个成员未由 访问说明符(如 public 、或)分隔,则 protected private 指向最后声明的成员的指针将比指向前面声明的成员的指针比较。

如果两个成员由 访问说明符 隔开,则结果是不确定的。

如果类类型为,则指向 union 该比较中不同数据成员的指针 union 相等。

如果两个指针指向同一数组的元素或指向超出数组末尾 1 的元素,则指向带较高下标的对象的指针会更高。 仅当指针引用同一数组中的对象或超出数组末尾 1 的位置时,才能保证指针比较有效。

该博文为原创文章,未经博主同意不得转载,如同意转载请注明博文出处,本文章博客地址:https://blog.youkuaiyun.com/it_cplusplus/article/details/118835799

【问题描述】 请根据给定的文法设计并实现语法分析程序,能基于上次作业的词法分析程序所识别出的单词,识别出各类语法成分。输入输出及处理要求如下: (1)需按文法规则,用递归子程序法对文法中定义的所有种语法成分进行分析; (2)为了方便进行自动评测,输入的被编译源文件统一命名为testfile.txt;输出的结果文件统一命名为output.txt ;结果文件中包含如下两种信息: 1)按词法分析识别单词的顺序,按行输出每个单词的信息(要求同词法分析作业,对于预读的情况不能输出)。 2)在下列高亮显示的语法分析成分分析结束前,另起一行输出当前语法成分的名字,形如“<常量说明>”(注:未要求输出的语法成分仍需要分析) <加法运算符> ::= +|- <乘法运算符> ::= *|/ <关系运算符::= <|<=|>|>=|!=== <字母> ::= _|a|...|z|A|...|Z <数字> ::= 0|<非零数字> <非零数字> ::= 1|...|9 <字符> ::= '<加法运算符>'|'<乘法运算符>'|'<字母>'|'<数字>' <字符串> ::= "{十进制编码为32,33,35-126的ASCII字符}" <程序> ::= [<常量说明>][<变量说明>]{<有返回值函数定义>|<无返回值函数定义>}<主函数> <常量说明> ::= const<常量定义>;{ const<常量定义>;} <常量定义> ::= int<标识符>=<整数>{,<标识符>=<整数>} | char<标识符>=<字符>{,<标识符>=<字符>} <无符号整数> ::= <非零数字>{<数字>}| 0 <整数> ::= [+|-]<无符号整数> <标识符> ::= <字母>{<字母>|<数字>} <声明头部> ::= int<标识符> |char<标识符> <变量说明> ::= <变量定义>;{<变量定义>;} <变量定义> ::= <类型标识符>(<标识符>|<标识符>'['<无符号整数>']'){,(<标识符>|<标识符>'['<无符号整数>']' )} //<无符号整数>表示数组元素的个数,其值需大于0 <类型标识符> ::= int | char <有返回值函数定义> ::= <声明头部>'('<参数表>')' '{'<复合语句>'}' <无返回值函数定义> ::= void<标识符>'('<参数表>')''{'<复合语句>'}' <复合语句> ::= [<常量说明>][<变量说明>]<语句列> <参数表> ::= <类型标识符><标识符>{,<类型标识符><标识符>}| <空> <主函数> ::= void main‘(’‘)’ ‘{’<复合语句>‘}’ <表达式> ::= [+|-]<项>{<加法运算符><项>} //[+|-]只作用于第一个<项> <项> ::= <因子>{<乘法运算符><因子>} <因子> ::= <标识符>|<标识符>'['<表达式>']'|'('<表达式>')'|<整数>|<字符>|<有返回值函数调用语句> <语句> ::= <条件语句>|<循环语句>| '{'<语句列>'}'| <有返回值函数调用语句>; |<无返回值函数调用语句>;|<赋值语句>;|<读语句>;|<写语句>;|<空>;|<返回语句>; <赋值语句> ::= <标识符>=<表达式>|<标识符>'['<表达式>']'=<表达式> <条件语句> ::= if '('<条件>')'<语句>[else<语句>] <条件> ::= <表达式><关系运算符><表达式> //整型表达式之间才能进行关系运算 |<表达式> //表达式为整型,其值为0条件为假,值不为0时条件为真 <循环语句> ::= while '('<条件>')'<语句>| do<语句>while '('<条件>')' |for'('<标识符>=<表达式>;<条件>;<标识符>=<标识符>(+|-)<步长>')'<语句> <步长>::= <无符号整数> <有返回值函数调用语句> ::= <标识符>'('<值参数表>')' <无返回值函数调用语句> ::= <标识符>'('<值参数表>')' <值参数表> ::= <表达式>{,<表达式>}|<空> <语句列> ::= {<语句>} <读语句> ::= scanf '('<标识符>{,<标识符>}')' <写语句> ::= printf '(' <字符串>,<表达式> ')'| printf '('<字符串> ')'| printf '('<表达式>')' <返回语句> ::= return['('<表达式>')'] 【输入形式】testfile.txt中的符合文法要求的测试程序。 【输出形式】按如上要求将语法分析结果输出至output.txt中,中文字符的编码格式要求是UTF-8。 【样例输入】 const int const1 = 1, const2 = -100; const char const3 = '_'; int change1; char change3; int gets1(int var1,int var2){ change1 = var1 + var2; return (change1); } void main(){ printf("Hello World"); printf(gets1(10, 20)); } 【样例输出】 CONSTTK const INTTK int IDENFR const1 ASSIGN = INTCON 1 <无符号整数> <整数> COMMA , IDENFR const2 ASSIGN = MINU - INTCON 100 <无符号整数> <整数> <常量定义> SEMICN ; CONSTTK const CHARTK char IDENFR const3 ASSIGN = CHARCON _ <常量定义> SEMICN ; <常量说明> INTTK int IDENFR change1 <变量定义> SEMICN ; CHARTK char IDENFR change3 <变量定义> SEMICN ; <变量说明> INTTK int IDENFR gets1 <声明头部> LPARENT ( INTTK int IDENFR var1 COMMA , INTTK int IDENFR var2 <参数表> RPARENT ) LBRACE { IDENFR change1 ASSIGN = IDENFR var1 <因子> <项> PLUS + IDENFR var2 <因子> <项> <表达式> <赋值语句> SEMICN ; <语句> RETURNTK return LPARENT ( IDENFR change1 <因子> <项> <表达式> RPARENT ) <返回语句> SEMICN ; <语句> <语句列> <复合语句> RBRACE } <有返回值函数定义> VOIDTK void MAINTK main LPARENT ( RPARENT ) LBRACE { PRINTFTK printf LPARENT ( STRCON Hello World <字符串> RPARENT ) <写语句> SEMICN ; <语句> PRINTFTK printf LPARENT ( IDENFR gets1 LPARENT ( INTCON 10 <无符号整数> <整数> <因子> <项> <表达式> COMMA , INTCON 20 <无符号整数> <整数> <因子> <项> <表达式> <值参数表> RPARENT ) <有返回值函数调用语句> <因子> <项> <表达式> RPARENT ) <写语句> SEMICN ; <语句> <语句列> <复合语句> RBRACE } <主函数> <程序>给我C++完整代码
最新发布
11-02
以下是一个使用 C++ 实现基于给定文法用递归子程序法进行语法分析的示例代码。该代码假设输入文件为 `testfile.txt`,输出文件为 `output.txt`,并且需要根据具体的文法规则进行相应的修改。 ```cpp #include <iostream> #include <fstream> #include <vector> #include <string> // 定义单词结构体 struct Token { std::string type; std::string value; }; // 假设的词法分析器,这里简单模拟 std::vector<Token> lexicalAnalysis(const std::string& input) { std::vector<Token> tokens; // 这里需要实现具体的词法分析逻辑 // 目前简单返回一个空的 token 列表 return tokens; } // 全局变量,用于存储当前处理的 token 位置 int currentTokenIndex = 0; std::vector<Token> tokens; // 获取当前 token Token getCurrentToken() { if (currentTokenIndex < tokens.size()) { return tokens[currentTokenIndex]; } return {"EOF", ""}; } // 移动到下一个 token void moveToNextToken() { if (currentTokenIndex < tokens.size()) { currentTokenIndex++; } } // 递归子程序法的语法分析函数示例,这里需要根据具体文法实现 // 例如,分析 <程序> 非终结符 void program() { // 这里需要根据具体文法规则实现对 <程序> 的分析 // 示例代码,简单输出当前 token 信息 Token currentToken = getCurrentToken(); std::cout << "Token Type: " << currentToken.type << ", Value: " << currentToken.value << std::endl; moveToNextToken(); } // 主函数,进行语法分析 void syntaxAnalysis() { program(); } int main() { // 读取输入文件 std::ifstream inputFile("testfile.txt"); if (!inputFile.is_open()) { std::cerr << "Failed to open input file." << std::endl; return 1; } std::string input((std::istreambuf_iterator<char>(inputFile)), std::istreambuf_iterator<char>()); inputFile.close(); // 进行词法分析 tokens = lexicalAnalysis(input); // 进行语法分析 syntaxAnalysis(); // 输出结果到文件 std::ofstream outputFile("output.txt"); if (!outputFile.is_open()) { std::cerr << "Failed to open output file." << std::endl; return 1; } // 输出单词信息 for (const auto& token : tokens) { outputFile << "Token Type: " << token.type << ", Value: " << token.value << std::endl; } outputFile.close(); return 0; } ``` ### 代码说明 1. **词法分析**:`lexicalAnalysis` 函数模拟了词法分析过程,需要根据具体的词法规则进行实现。 2. **递归子程序法**:`program` 函数是递归子程序法的示例,需要根据具体的文法规则进行实现。 3. **输入输出**:程序从 `testfile.txt` 读取输入,将结果输出到 `output.txt`。 ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值