关于【于和伟《大决战》中首演林彪】,今天犇犇小编给您分享一下,如果对您有所帮助别忘了关注本站哦。
内容导航:1、这6种编码方法,你掌握了几个?2、于和伟《大决战》中首演林彪1、这6种编码方法,你掌握了几个?
阿里妹导读:Don Roberts 提出的一条重构准则:第一次做某件事时只管去做;第二次做类似的事时会产生反感,但无论如何还是可以去做;第三次再做类似的事时,你就应该重构。
编码也是如此,当多次编写类似的代码时,我们需要考虑是否有一种方法能够提高编码速度,让编码速度“起飞”?高德地图技术专家陈昌毅(常意)多年来致力于敏捷开发,总结了一套编码的方法论,有助于程序员"快速、优质、高效"地进行编码。
方法1:手工编写代码
大多数刚学习 Java 的程序员,都会怀着一种崇敬的仪式感,一字一句地在开发工具上敲出以下代码:
public class Test { public static void main(String[] args) { System.out.println("Hello world!"); }}
没错,这就是经典的"Hello world",这也是大多数人手工编写的第一个程序。
手工编写代码,更能体现一个程序员的基本素质。有很多公司,都把上机编程考试作为面试的重要手段之一。面试者需要根据题目的要求,挑选一款熟悉的编程工具(比如Eclipse),手工编写代码并调试运行通过。在整个过程中,不能通过网络搜索答案,不能查看联机帮助文档,要求面试者必须手工编写代码,主要是考察面试者手工编写代码的能力——语法、函数、逻辑、思维、算法以及动手能力。
手工编写代码,是一个优秀程序员必须具备的基础能力。手工编写代码正如提笔写文章,语法就是遣词造句的方法、函数就是组成文章的词句、类库就是据经引典的掌故、架构就是行文表述的体裁、功能就是写作文章的主旨、算法就是组织语言的逻辑……所以,只要掌握一门程序语言的语法、学习一堆基础类库的函数、引用一些所需的第三方类库、选择一款成熟稳定的架构、明确一下产品需求的功能、挑选一种实现逻辑的算法……手工编写代码就会像写文章一样手到擒来。
方法2:复制粘贴代码
常言道:"熟读唐诗三百首,不会作诗也会吟。"编码也是同样的道理,编码的第一步就是模仿,简单地说就是"抄代码"——复制粘贴代码。复制粘贴代码是一门艺术,用好了编码会事半功倍。但是,没有检验过的东西,终究是不可全信的。当看到需要的代码时,在复制粘贴前,我们都需要仔细研读、认真思考、详细甄别……很多东西,都是仁者见仁、智者见智的东西,适合别的场景但不一定适合你的场景。作为一名合格的程序员,切不可一味地"拿来主义"。
1.为什么要复制粘贴代码
复制粘贴现有代码,可以节省开发时间;复制粘贴稳定代码,可以降低系统故障风险;复制粘贴网络代码,可以把别人的成果化为己用。2.复制粘贴代码带来问题
你对复制的代码理解程度是多少?实现逻辑是否合理?能不能稳定运行?存在多少潜在的 Bug?这个代码在项目中已经复制粘贴了多少次?根据“三则重构”原则,你是否需要对这些相同代码进行重构?代码被复制粘贴次数越多,带来的代码维护问题越多。多个代码版本的更改和修正,要保持这些代码的同步,就必须需要在每一处进行同样的修改,增加了维护的成本和风险。总之,复制粘贴代码,跟其它编码方法一样,没有优劣对错之分。它只是一种方法,你可以善用,也可以滥用。如果我们用到了复制粘贴,我们就必须为结果负责。
方法3:用文本替换生成代码
1.生成代码样例
已经编写好的用户查询相关代码:
/** 查询用户服务函数 */public PageData<UserVO> queryUser(QueryUserParameterVO parameter) { Long totalCount = userDAO.countByParameter(parameter); List<UserVO> userList = null; if (Objects.nonNull(totalCount) && totalCount.compareTo(0L) > 0) { userList = userDAO.queryByParameter(parameter); } return new PageData<>(totalCount, userList);}/** 查询用户控制器函数 */@RequestMapping(path = "/queryUser", method = RequestMethod.POST)public Result<PageData<UserVO>> queryUser(@Valid @RequestBody QueryUserParameterVO parameter) { PageData<UserVO> pageData = userService.queryUser(parameter); return Result.success(pageData);}
如果我们要编写公司查询相关代码,其代码形式与用户查询类似,整理出替换关系如下:
把"用户"替换为"公司";把"User"替换为"Company";把"user"替换为"company"。利用 Notepad、EditPlus 等文本编辑器,选择区分大小写,进行普通文本替换,最终得到结果如下:
/** 查询公司服务函数 */public PageData<CompanyVO> queryCompany(QueryCompanyParameterVO parameter) { Long totalCount = companyDAO.countByParameter(parameter); List<CompanyVO> companyList = null; if (Objects.nonNull(totalCount) && totalCount.compareTo(0L) > 0) { companyList = companyDAO.queryByParameter(parameter); } return new PageData<>(totalCount, companyList);}/** 查询公司控制器函数 */@RequestMapping(path = "/queryCompany", method = RequestMethod.POST)public Result<PageData<CompanyVO>> queryCompany(@Valid @RequestBody QueryCompanyParameterVO parameter) { PageData<CompanyVO> pageData = companyService.queryCompany(parameter); return Result.success(pageData);}
利用文本替换生成代码,整段代码生成时间不会超过1分钟。
2.主要优缺点
主要优点:
生成代码速度较快。主要缺点:
必须编写样例代码;只适用于文本替换的情景。方法4:用Excel公式生成代码
Excel 的公式非常强悍,可以用于编写一些公式化的代码。
1.利用 Excel 公式生成模型类
从 WIKI 上拷贝接口模型定义到 Excel 里,样例数据内容如下:
编写 Excel 公式如下:
= "/** "&D6&IF(ISBLANK(F6), "", "("&F6&")")&" */ "&IF(E6 = "否", IF(C6 = "String", "@NotBlank", "@NotNull"), "")&" private "&C6&" "&B6&";"
利用公式生成代码如下:
/** 用户标识 */ @NotNull private Long id;/** 用户名称 */ @NotBlank private String name;/** 用户性别(0:未知;1:男;2:女) */ @NotNull private Integer sex;/** 用户描述 */ private String description;
创建模型类,整理代码如下:
/** 用户DO类 */public class UserDO { /** 用户标识 */ @NotNull private Long id; /** 用户名称 */ @NotBlank private String name; /** 用户性别(0:未知;1:男;2:女) */ @NotNull private Integer sex; /** 用户描述 */ private String description; ......}
2.利用 Excel 公式生成枚举类
从 WIKI 上拷贝枚举定义到 Excel 里,样例数据内容如下:
编写 Excel 公式如下:
="/** "&D2&"("&B2&") */"&C2&"("&B2&", """&D2&"""),"
利用公式生成代码如下:
/** 空(0) */NONE(0, "空"),/** 男(1) */MAN(1, "男"),/** 女(2) */WOMAN(2, "女"),
创建枚举类,整理代码如下:
/** 用户性别枚举 */public enum UserSex { /** 枚举定义 */ /** 空(0) */ NONE(0, "空"), /** 男(1) */ MAN(1, "男"), /** 女(2) */ WOMAN(2, "女"); ......}
3.利用 Excel 公式生成数据库语句
用 Excel 整理的公司列表如下,需要整理成 SQL 语句直接插入数据库:
编写 Excel 公式如下:
= "('"&B2&"', '"&C2&"', '"&D2&"', '"&E2&"'),"
利用公式生成 SQL 如下:
('高德', '首开大厦', '(010)11111111', 'gaode@xxx.com'),('阿里云', '绿地中心', '(010)22222222', 'aliyun@xxx.com'),('菜鸟', '阿里中心', '(010)33333333', 'cainiao@xxx.com'),
添加 into 语句头,整理 SQL 如下:
insert into t_company(name, address, phone, email) values('高德', '首开大厦', '(010)11111111', 'gaode@xxx.com'),('阿里云', '绿地中心', '(010)22222222', 'aliyun@xxx.com'),('菜鸟', '阿里中心', '(010)33333333', 'cainiao@xxx.com');
4.主要优缺点
主要优点:
适用于表格化数据的代码生成;写好公式后,拖拽生成代码,生成速度较快。主要缺点:
不适用于复杂功能的代码生成。方法5:用工具生成代码
用工具生成代码,顾名思义就是借用已有的工具生成代码。很多开发工具都提供一些工具生成代码,比如:生成构造函数,重载基类/接口函数,生成 Getter/Setter 函数,生成 toString 函数……能够避免很多手敲代码。还有一些生成代码插件,也可以生成满足某些应用场景的代码。
这里以 mybatis-generator 插件生成代码为例,介绍如何利用工具生成代码。
1.安装运行插件
具体方法这里不再累述,自行上网搜索文档了解。
2.生成代码样例
| 2.1.生成模型类代码
文件 User.java 内容:
......public class User { private Long id; private String user; private String password; private Integer age; ......}
| 2.2.生成映射接口代码
文件 UserMapper.java 内容:
......public interface UserMapper { User selectByPrimaryKey(Long id); ......}
| 2.3.生成映射XML代码
文件 UserMapper.xml 内容:
......<mapper namespace="com.test.dao.UserMapper" > <resultMap id="BaseResultMap" type="com.test.pojo.User" > <id column="id" property="id" jdbcType="BIGINT" /> <result column="user" property="user" jdbcType="VARCHAR" /> <result column="password" property="password" jdbcType="VARCHAR" /> <result column="age" property="age" jdbcType="INTEGER" /> </resultMap> <sql id="Base_Column_List" > id, user, password, age </sql> <select id="selectByPrimaryKey" resultMap="BaseResultMap" parameterType="java.lang.Long" > select <include refid="Base_Column_List" /> from test_user where id = #{id,jdbcType=BIGINT} </select> ......</mapper>
3.主要优缺点
主要优点:
利用生成代码插件,生成代码速度较快;利用插件配置文件,控制生成想要的功能代码。主要缺点:
需要时间研究和熟悉生成代码插件的使用;生成的代码不一定满足代码规范,每次生成后需进行代码合规;重新生成代码后,容易覆盖自定义代码(建议维护单独的生成代码库,通过DIFF 工具比较代码差异,然后再赋值粘贴差异代码)。方法6:用代码生成代码
用代码生成代码,就是自己编写代码,按照自己的格式生成代码。下面,以生成基于 MyBatis 的数据库访问代码为例说明。
1.查询表格信息
首先,我们要从数据库中拿到我们生成代码所需要的表和列相关信息。
| 1.1.查询表信息
查询表信息语句:
select t.table_name as '表名称', t.table_comment as '表备注'from information_schema.tables twhere t.table_schema = ?and t.table_type = 'BASE TABLE'and t.table_name = ?;
其中,第1个问号赋值数据库名称,第2个问号赋值表名称。
查询表信息结果:
| 1.2.查询列信息
查询列信息语句:
select c.column_name as '列名称', c.column_comment as '列备注', c.data_type as '数据类型', c.character_maximum_length as '字符长度', c.numeric_precision as '数字精度', c.numeric_scale as '数字范围', c.column_default as '', c.is_nullable as '是否可空', c.column_key as '列键名'from information_schema.columns cwhere c.table_schema = ?and c.table_name = ?order by c.ordinal_position;
其中,第1个问号赋值数据库名称,第2个问号赋值表名称。
查询列信息结果:
2.编写生成代码
| 2.1.编写生成模型类代码
/** 生成模型类文件函数 */private void generateModelClassFile(File dir, Table table, List<Column> columnList) throws Exception { try (PrintWriter writer = new PrintWriter(new File(dir, className + "DO.java"))) { String className = getClassName(table.getTableName()); String classComments = getClassComment(table.getTableComment()); writer.println("package " + groupName + "." + systemName + ".database;"); ...... writer.println("/** " + classComments + "DO类 */"); writer.println("@Getter"); writer.println("@Setter"); writer.println("@ToString"); writer.println("public class " + className + "DO {"); for (Column column : columnList) { String fieldType = getFieldType(column); String fieldName = getFieldName(column.getColumnName()); String fieldComment = getFieldComment(column); writer.println("\t/** " + fieldComment + " */"); writer.println("\tprivate " + fieldType + " " + fieldName + ";"); } writer.println("}"); }}
| 2.2.编写生成 DAO 接口代码
/** 生成DAO接口文件函数 */private void generateDaoInterfaceFile(File dir, Table table, List<Column> columnList, List<Column> pkColumnList) throws Exception { try (PrintWriter writer = new PrintWriter(new File(dir, className + "DAO.java"))) { String className = getClassName(table.getTableName()); String classComments = getClassComment(table.getTableComment()); writer.println("package " + groupName + "." + systemName + ".database;"); ...... writer.println("/** " + classComments + "DAO接口 */"); writer.println("public interface " + className + "DAO {"); writer.println("\t/** 获取" + classComments + "函数 */"); writer.print("\tpublic " + className + "DO get("); boolean isFirst = true; for (Column pkColumn : pkColumnList) { if (!isFirst) { writer.print(", "); } else { isFirst = false; } String fieldType = getFieldType(pkColumn); String fieldName = getFieldName(pkColumn.getColumnName()); writer.print("@Param(\"" + fieldName + "\") " + fieldType + " " + fieldName); } writer.println(");"); ...... writer.println("}"); }}
| 2.3.编写生成 DAO 映射代码
/** 生成DAO映射文件函数 */private void generateDaoMapperFile(File dir, Table table, List<Column> columnList, List<Column> pkColumnList) throws Exception { try (PrintWriter writer = new PrintWriter(new File(dir, className + "DAO.xml"))) { String className = getClassName(table.getTableName()); String classComments = getClassComment(table.getTableComment()); writer.println("<?xml version=\"1.0\" encoding=\"UTF-8\"?>"); ...... writer.println("<!-- " + classComments + "映射 -->"); writer.println("<mapper namespace=\"" + groupName + "." + systemName + ".database." + className + "DAO\">"); writer.println("\t<!-- 所有字段语句 -->"); writer.println("\t<sql id=\"fields\">"); if (CollectionUtils.isNotEmpty(columnList)) { boolean isFirst = true; String columnName = getColumnName(pkColumn.getColumnName()); for (Column column : columnList) { if (isFirst) { isFirst = false; writer.println("\t\t" + columnName); } else { writer.println("\t\t, " + columnName); } } } writer.println("\t</sql>"); writer.println("\t<!-- 获取" + classComments + "函数语句 -->"); writer.println("\t<select id=\"get\" resultType=\"" + groupName + "." + systemName + ".database." + className + "DO\">"); writer.println("\t\tselect"); writer.println("\t\t<include refid=\"fields\"/>"); writer.println("\t\tfrom " + table.getTableName()); boolean isFirst = true; for (Column pkColumn : pkColumnList) { String columnName = getColumnName(pkColumn.getColumnName()); String fieldName = getFieldName(pkColumn.getColumnName()); writer.print("\t\t"); if (isFirst) { writer.print("where"); isFirst = false; } else { writer.print("and"); } writer.println(" " + columnName + " = #{" + fieldName + "}"); } writer.println("\t</select>"); writer.println("</mapper>"); }}
3.生成相关代码
| 3.1.生成的模型类代码
/** 组织公司DO类 */@Getter@Setter@ToStringpublic class OrgCompanyDO { /** 公司标识 */ private Long id; /** 公司名称 */ private String name; /** 联系地址 */ private String address; /** 公司描述 */ private String description;}
| 3.2.生成的 DAO 接口代码
/** 组织公司DAO接口 */public interface OrgCompanyDAO { /** 获取组织公司函数 */ public OrgCompanyDO get(@Param("id") Long id);}
| 3.3.生成的 DAO 映射代码
<!-- 组织公司映射 --><mapper namespace="xxx.database.OrgCompanyDAO"> <!-- 所有字段语句 --> <sql id="fields"> id , name , address , description </sql> <!-- 获取组织公司函数语句 --> <select id="get" resultType="xxx.database.OrgCompanyDO"> select <include refid="fields"/> from org_company where id = #{id} </select></mapper>
3.主要优缺点
主要优点:
代码格式可以定制,保证生成代码合规;代码功能可以定制,只生成需要的代码;经过前期代码沉淀后,后期能够直接使用。主要缺点:
需要研究数据来源,保证能获取到生成代码所需的数据;需要建立数据模型、编写生成代码,耗费时间比较长。终极方法:无招胜有招
编码的终极方法,是不是直接对着电脑说需求,然后电脑就自动生成代码了?未来科技发展到一定水平后,这种情况或许会变成现实。但是,目前这种情况是不现实的。现实中,想要做到"大口一张、代码就来",除非你是老板、产品经理或者技术管理者。
编码的终极方法是“无招胜有招”,"无招"并不是不讲究"招式",而是不拘泥于某一"招式",信手拈来合适的"招式"为宜。本文中列举的各种编码方法,没有高低优劣之分,只有合不合适之说。所以,灵活地运用各种编码方法,就是编码的终极方法。
代码规范化
在上面的各种编码方法中,很多方法都需要手工编写样例代码。如果你的代码不遵循代码规范,就很难发现代码之间的共性,并抽象出能够作为标准的样例代码;如果作为标准的样例代码不满足代码规范,必然导致生成的代码也不满足代码规范,于是把这些不规范放大了十倍、百倍甚至千倍。所以,代码规范化是编码的重中之重。
作者:陈昌毅
2、于和伟《大决战》中首演林彪
于和伟《大决战》中首演林彪
这几天一直在追电视剧《大决战》,很有质感,尤其几位主要演员的表现,看得非常过瘾。
之前写过唐国强的稳,王劲松的眼神,在重庆谈判之前的餐桌上,一罐小小的辣椒,也能被两位演出不一样的博弈!不得不让人感慨:懂表演的好演员,总是能在各种细节中塑造人物,非常生动。
播出几集后,还有一位重要演员的登场,让人忍不住多看几眼——
于和伟,在《大决战》中饰演林彪。
这不是于和伟第一次饰演历史人物,之前的曹操和陈独秀,于和伟都演得人心服口服,代入感非常强,而首次饰演林彪,对他绝对是一次挑战。
首先是在人物外形上,有着比较大的差距。之前,于和伟的林彪造型首次曝光,便引发了很多观众的强烈关注。
因为于和伟的演技,让很多人都对他这次的出演寄予了极大的期待,而他的造型一曝光,不少人认为他化妆后眉毛很抢眼。据悉,于和伟扮演林彪,导演高希希也非常满意,片方还曝光了于和伟当时在剧组定妆做造型时的内容。
大家认为,于和伟的'颧骨、嘴型都很像,再稍微加以特型化妆的辅助,造型还是很到位的。不过,还是有人认为于和伟略胖了一点,应该要再瘦一点,就能更加在外形上接近人物。
在30年前的电影《大决战》中,扮演林彪的是马绍信老师,他的外形极其接近,清瘦眉浓,气质也非常像,而于和伟扮演的林彪造型曝光后,难免被观众进行比较。
这次大家没有担心于和伟的演技,反而是担心因为外形不是那么接近,可能会让人无法入戏。
不过,等到于和伟扮演的林彪亮相之后,大家的这个顾虑很快被打消了,于和伟依然是在表演上抠细节抠得非常到位!
目前而言,于和伟扮演的林彪能否超过马绍信版林彪,还不太好说,但是在各种细节之中,于和伟对人物的拿捏,非常有戏。
只能说,于和伟不愧是于和伟。
其实,在近年来的主旋律影视作品中,观众也开始逐渐接受明星,甚至是流量偶像出演历史人物,但前提是,真的能打破大家的固有印象,真正达到忘我的表演境界。而在于和伟看来,扮演历史人物,演员塑造人物应该放在第一位,而不是那么追求形似,因为“形似是表皮,神似是内核”。
“我觉得他是不是这个人,(要看)他的内心世界,他的精神气质是不是这样的。”
“如果是这样的话,观众就会认可,就会感受得到,主要是他的精神、内心、性格、人格,我觉得这个都是内(在)的部分。”
剧版《大决战》中,于和伟便是从细节入手,刻画林彪。
于和伟饰演的林彪,在剧中的第一个出场的镜头有些特别:林彪骑在驴背上,在行军途中小睡,然后被通讯员喊醒,向他汇报并呈交最新的军委电报。
林彪抬头,电报中的命令是:不去冀东,改去东北。
林彪在驴背上睡觉这一幕,非常细节,因为当时战局变化,多次更改任命,最后辗转多次到达东北。因为长途奔波和操劳,于和伟一出场就对人物的这个细节抠得很到位,把一位将领首先以普通人的视角呈现,更加细腻立体呈现人物。
第二个细节,剧中于和伟饰演的林彪,一边吃黄豆一边思考,还有多处关于他吃黄豆的特写。
林彪在饮食上喜欢粗茶淡饭,据曾经照顾过林彪一家日常生活的王淑媛回忆,林彪吃馒头时总是先剥掉馒头皮,再切成片,用开水泡着吃。而林彪最固定的一个食物,就是黄豆,有时煮着吃,有时炸着吃,有时候是吃黄豆磨的豆腐。
而平时他喜欢用手抓着炒熟的黄豆吃,来客人也喜欢用黄豆招呼客人。还有人回忆说,林彪打仗的时候,不管到哪里,就是喜欢一边看着地图,一边吃炒黄豆。
剧中,于和伟抓住了这个细节,用吃黄豆这个生活细节,突出了人物的喜静和善于思考,而且,还有用黄豆在地图上排兵布阵,可以说抠细节细致到可以打满分。
第三个细节,就是于和伟饰演的林彪,突出他喜欢独处安静思考,不爱开会,一心钻研军事。
在《大决战》第四集中,罗荣桓、陈 云、刘亚楼为了请林彪外出开会,还专门想办法“折磨”他。当时,陈 云出了个主意,他们几个人在林彪屋外开枪打靶,不停弄出声音。
这样的噪音显然干扰到了正在屋里看地图分析的林彪,他用纸团塞住耳朵,依然不想被外界打扰,只想沉浸在自我的思考当中。
可是,屋外依然枪声不断,这让林彪再也无法静下心来看地图思考,最后不得不从屋子里走出来和他们碰面,被“逼”去开会。
在会上,林彪对军事的专注再次凸现出来,他对陈 云他们提出的政务问题都予以放权,强调“我呢,继续专心军事工作”。之后,他速战速决,几分钟就开完了会,说“行了,会开完了”,就转身走了,继续他的独处思考了。
虽然这几个细节都不是很多人期盼的战争场面,但于和伟极强的可塑性、善于思考和抠细节的表演技巧,又再次呈现于观众面前,让人逐渐感受到他在剧版《大决战》用细节篆刻人物的毛边,让史册中的林彪变得鲜活真实。
此前,《大决战》首支预告片中,给于和伟版林彪的镜头就颇多,其中他有一句铿锵有力的台词:“我不要伤亡情况,我只要塔山!”又让人看到有气魄、有威严的将领气质。
第一次出演林彪,再次尝试突破自我,于和伟的外形也许不是最像的,但演技是真的在细节中发光。
这让人更加期待《大决战》后面的战争大戏了。
于和伟《大决战》中首演林彪
这几天一直在追电视剧《大决战》,很有质感,尤其几位主要演员的表现,看得非常过瘾。
之前写过唐国强的稳,王劲松的眼神,在重庆谈判之前的餐桌上,一罐小小的辣椒,也能被两位演出不一样的博弈!不得不让人感慨:懂表演的好演员,总是能在各种细节中塑造人物,非常生动。
播出几集后,还有一位重要演员的登场,让人忍不住多看几眼——
于和伟,在《大决战》中饰演林彪。
这不是于和伟第一次饰演历史人物,之前的曹操和陈独秀,于和伟都演得人心服口服,代入感非常强,而首次饰演林彪,对他绝对是一次挑战。
首先是在人物外形上,有着比较大的差距。之前,于和伟的林彪造型首次曝光,便引发了很多观众的强烈关注。
因为于和伟的演技,让很多人都对他这次的出演寄予了极大的期待,而他的造型一曝光,不少人认为他化妆后眉毛很抢眼。据悉,于和伟扮演林彪,导演高希希也非常满意,片方还曝光了于和伟当时在剧组定妆做造型时的内容。
大家认为,于和伟的'颧骨、嘴型都很像,再稍微加以特型化妆的辅助,造型还是很到位的。不过,还是有人认为于和伟略胖了一点,应该要再瘦一点,就能更加在外形上接近人物。
在30年前的电影《大决战》中,扮演林彪的是马绍信老师,他的外形极其接近,清瘦眉浓,气质也非常像,而于和伟扮演的林彪造型曝光后,难免被观众进行比较。
这次大家没有担心于和伟的演技,反而是担心因为外形不是那么接近,可能会让人无法入戏。
不过,等到于和伟扮演的林彪亮相之后,大家的这个顾虑很快被打消了,于和伟依然是在表演上抠细节抠得非常到位!
目前而言,于和伟扮演的林彪能否超过马绍信版林彪,还不太好说,但是在各种细节之中,于和伟对人物的拿捏,非常有戏。
只能说,于和伟不愧是于和伟。
其实,在近年来的主旋律影视作品中,观众也开始逐渐接受明星,甚至是流量偶像出演历史人物,但前提是,真的能打破大家的固有印象,真正达到忘我的表演境界。而在于和伟看来,扮演历史人物,演员塑造人物应该放在第一位,而不是那么追求形似,因为“形似是表皮,神似是内核”。
“我觉得他是不是这个人,(要看)他的内心世界,他的精神气质是不是这样的。”
“如果是这样的话,观众就会认可,就会感受得到,主要是他的精神、内心、性格、人格,我觉得这个都是内(在)的部分。”
剧版《大决战》中,于和伟便是从细节入手,刻画林彪。
于和伟饰演的林彪,在剧中的第一个出场的镜头有些特别:林彪骑在驴背上,在行军途中小睡,然后被通讯员喊醒,向他汇报并呈交最新的军委电报。
林彪抬头,电报中的命令是:不去冀东,改去东北。
林彪在驴背上睡觉这一幕,非常细节,因为当时战局变化,多次更改任命,最后辗转多次到达东北。因为长途奔波和操劳,于和伟一出场就对人物的这个细节抠得很到位,把一位将领首先以普通人的视角呈现,更加细腻立体呈现人物。
第二个细节,剧中于和伟饰演的林彪,一边吃黄豆一边思考,还有多处关于他吃黄豆的特写。
林彪在饮食上喜欢粗茶淡饭,据曾经照顾过林彪一家日常生活的王淑媛回忆,林彪吃馒头时总是先剥掉馒头皮,再切成片,用开水泡着吃。而林彪最固定的一个食物,就是黄豆,有时煮着吃,有时炸着吃,有时候是吃黄豆磨的豆腐。
而平时他喜欢用手抓着炒熟的黄豆吃,来客人也喜欢用黄豆招呼客人。还有人回忆说,林彪打仗的时候,不管到哪里,就是喜欢一边看着地图,一边吃炒黄豆。
剧中,于和伟抓住了这个细节,用吃黄豆这个生活细节,突出了人物的喜静和善于思考,而且,还有用黄豆在地图上排兵布阵,可以说抠细节细致到可以打满分。
第三个细节,就是于和伟饰演的林彪,突出他喜欢独处安静思考,不爱开会,一心钻研军事。
在《大决战》第四集中,罗荣桓、陈 云、刘亚楼为了请林彪外出开会,还专门想办法“折磨”他。当时,陈 云出了个主意,他们几个人在林彪屋外开枪打靶,不停弄出声音。
这样的噪音显然干扰到了正在屋里看地图分析的林彪,他用纸团塞住耳朵,依然不想被外界打扰,只想沉浸在自我的思考当中。
可是,屋外依然枪声不断,这让林彪再也无法静下心来看地图思考,最后不得不从屋子里走出来和他们碰面,被“逼”去开会。
在会上,林彪对军事的专注再次凸现出来,他对陈 云他们提出的政务问题都予以放权,强调“我呢,继续专心军事工作”。之后,他速战速决,几分钟就开完了会,说“行了,会开完了”,就转身走了,继续他的独处思考了。
虽然这几个细节都不是很多人期盼的战争场面,但于和伟极强的可塑性、善于思考和抠细节的表演技巧,又再次呈现于观众面前,让人逐渐感受到他在剧版《大决战》用细节篆刻人物的毛边,让史册中的林彪变得鲜活真实。
此前,《大决战》首支预告片中,给于和伟版林彪的镜头就颇多,其中他有一句铿锵有力的台词:“我不要伤亡情况,我只要塔山!”又让人看到有气魄、有威严的将领气质。
第一次出演林彪,再次尝试突破自我,于和伟的外形也许不是最像的,但演技是真的在细节中发光。
这让人更加期待《大决战》后面的战争大戏了。
于和伟《大决战》中首演林彪
于和伟个人简介
于和伟,1971年5月4日出生于辽宁省抚顺市东洲区,中国内地影视男演员,毕业于上海戏剧学院1996届表演本科班。
1999年,参演个人首部电视剧《曹操》,从而正式进入演艺圈。2003年,参演高希希执导的抗战剧《历史的天空》 [1] 。2004年,在情感剧《搭错车》中饰演苏民生。2009年,在古装剧《三国》中饰演刘备 [2] 。2011年,搭档主演电视剧《青盲》 [3] 。2011年,凭借电视剧《幸福在路上》获得南方盛典最佳男演员奖 [4] 。2012年5月22日,获得MSN星月年度最具价值男演员奖。2014年,主演都市情感剧《下一站婚姻》 [5] ,并凭借该剧获得第17届华鼎奖当代题材最佳男演员奖 [6] 。
2015年8月9日,凭借电视剧《下一站婚姻》获得第17届华鼎奖最佳男演员奖 [6] 。2017年9月16日,凭借电影《我不是潘金莲》获得第31届中国电影金鸡奖最佳男配角 [7] 。2018年,于和伟凭借《大军师司马懿之军师联盟》获得第24届上海电视节“白玉兰奖”最佳男配角 [8] 。2019年,主演电视剧《巡回检察组》 [9] ;同年,获得第十七届电影表演艺术学会奖 [10] 。2021年6月10日,凭借《觉醒年代》获得第27届上海电视节-白玉兰奖最佳男主角奖。 [107] 6月24日,参演的《大决战》开播。 [108]
中文名
于和伟
外文名
Hewei Yu [106]
别 名
和和、皇叔、主公、于叔
国 籍
中国
民 族
回族
出生地
辽宁省抚顺市东洲区
出生日期
1971年5月4日
星 座
金牛座
血 型
A型
身 高
179 cm
体 重
70 kg
毕业院校
上海戏剧学院
职 业
演员
经纪公司
于和伟工作室
代表作品
悬崖之上、三国、大军师司马懿之军师联盟、猎毒人、刑警队长、决胜法庭、巡回检察组、刺杀小说家、觉醒年代、建军大业
主要成就
第31届中国电影金鸡奖最佳男配角 [11]
第24届上海电视节白玉兰奖最佳男配角奖 [8]
第15届上海电视白玉兰奖最佳男演员提名
第31届中国电视剧飞天奖优秀男演员奖提名 [64]
第17届华鼎奖中国当代题材电视剧最佳男演员奖展开
这就是关于《于和伟《大决战》中首演林彪,这6种编码方法,你掌握了几个》的所有内容,希望对您能有所帮助!